我正在尝试对服务堆栈端点执行POST,并且服务正确映射请求,但根本不会对RequestDTO进行水合。
服务方法
public object Post(PostUpdateContactRequest request)
{
// Breakpoint below, has hit with no problem. Everything is in the request null though.
Contacts upd_contact = Contacts.Load(request.Contactid);
//..other vlaidation/code/etc
this.m_repository.PostEditContact(upd_contact);
return new HttpResult() { StatusCode = System.Net.HttpStatusCode.Created };
}
RequestDTO
[Route("/contact/update/","POST")]
public class PostUpdateContactRequest
{
public virtual long Contactid { get; set; }
public virtual string Firstname { get; set; }
public virtual string Lastname { get; set; }
public virtual string Middlename { get; set; }
public virtual string Suffix { get; set; }
public virtual string Homephone { get; set; }
public virtual string Mobilephone { get; set; }
public virtual string Workphone { get; set; }
public virtual string Addressline1 { get; set; }
public virtual string Addressline2 { get; set; }
public virtual string City { get; set; }
public virtual string State { get; set; }
public virtual string Zipcode { get; set; }
public virtual string Nickname { get; set; }
public virtual string Email { get; set; }
}
JSON数据(生成的数据不真实)
{ "Addressline1" : "Ap #638-3472 Dolor. Road",
"Addressline2" : "",
"City" : "Forest Lake",
"Contactid" : "1",
"Email" : "nibh.sit.amet@gravida.ca",
"Firstname" : "Amela",
"Homephone" : "222-222-2222",
"Lastname" : "Airheart",
"Middlename" : " S",
"Mobilephone" : "1-111-111-1111",
"Nickname" : "Thomas",
"State" : "TN",
"Suffix" : "NA",
"Workphone" : "(888)-888-8888",
"Zipcode" : "32549"
}
我错过了什么吗?
更多研究后的更新:
我的Jquery客户端中出现ContentType + CORs + Datatype导致彼此冲突。在阅读了很多关于正在使用的CORS(它在这里)之后,每个人都说要使用'jsonp'的contentType,这会导致HTTP OPTIONS发生,并且我的服务断点不再受到攻击。显然,因为动词不再匹配。
切换到contentType'json'会导致GET。再一次,动词不匹配。我的服务期待POST,POST。
所有这一切都试图让JSON对象发布。
使用:
$.ajax({
url: post_url,
type: 'POST',
data: jdata,
dataType: 'json',
contentType: 'application/json',
success: function (data) {
alert('updated!');
},
error: function (xhr, textStatus, error) {
alert(xhr);
alert(textStatus);
alert(error);
}
});
如果我删除了我添加的东西,让jquery决定这些选项,我再次获得一个POST,但没有JSON对象。 IT将内容类型切换为:Content-Type application / x-www-form-urlencoded;字符集= UTF-8
我的服务不是在寻找,而是忽略,从不反序列化任何东西。但是Object正试图发布!以下是标题:
请求标题
POST /AerosMobileInterface/contact/update/ HTTP/1.1
Host: localhost
User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:17.0) Gecko/20100101 Firefox/17.0
Accept: */*
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Referer: http://localhost:7072/AjaxDetail.htm?Contactid=98
Content-Length: 387
Origin: http://localhost:7072
Pragma: no-cache
Cache-Control: no-cache
响应标题
HTTP/1.1 500 NullReferenceException
Cache-Control: private
Content-Type: text/html
Server: Microsoft-IIS/7.5
X-Powered-By: ServiceStack/3.932 Win32NT/.NET, ASP.NET
X-AspNet-Version: 4.0.30319
access-control-allow-headers: content-type
Access-Control-Allow-Origin: *
Date: Sun, 06 Jan 2013 17:13:30 GMT
Content-Length: 9914
POST参数 {“Addressline1”:“Ap#638-3472 Dolor.Road”, “Addressline2”:“”, “城市”:“森林湖”, “Contactid”:“1”, “电子邮件”:“nibh.sit.amet@gravida.ca”, “名字”:“Amela”, “Homephone”:“222-222-2222”, “姓氏”:“Airheart”, “中间名”, “手机”:“1-111-111-1111”, “昵称”:“托马斯”, “国家”:“TN”, “后缀”:“NA”, “Workphone”:“(888)-888-8888”, “邮编”:“32549” }
看来我无法获得内容类型的行为!我真的不想破解Jquery,HTTP和ServiceStack来做这么简单的事情。有很多SO帖子,人们有类似的问题,并且更改$ .ajax函数的contentType和DataType适用于他们,但它不适用于此。
由于
更新: - jdata是$ .ajax调用中作为data参数传递的变量,是一个{}对象。我做了一个console.log(jdata)来验证它实际上是一个对象,而不是被误认为是一个字符串,或者其他一些会混淆$ .ajax的类型。 Firebug似乎认为它是一个有效的对象,它产生了该对象的正确json投影。
看起来$ .ajax正试图将该对象放在REST调用的查询字符串中。我能够改变我的服务,以便它不再接受查询字符串中的值。这导致服务方法无法触发。
答案 0 :(得分:0)
因此,对于服务堆栈,当我使用application/x-www-form-urlencoded; charset=UTF-8
时,发布到其他端点似乎最适合我。我会在客户端张贴这样的东西:
$.ajax({
url: post_url,
type: 'POST',
data: jdata,
dataType: 'json', // Accept: application/json
success: function (data) {
alert('updated!');
},
error: function (xhr, textStatus, error) {
// according to the docs, this isn't
// called for cross domain requests...
},
complete: function(xhr, status) {
if (status != 'success') alert('there was a error!');
}
});
也就是说,这不会解决您的跨域问题。您需要设置服务堆栈以支持CORS
,这里有一个很好的解释: