gpt4 book ai didi

ServiceStack - 反序列化规则?

转载 作者:行者123 更新时间:2023-12-04 05:14:05 25 4
gpt4 key购买 nike

我正在尝试对服务堆栈端点执行 POST,并且服务正确映射请求,但根本不对 RequestDTO 进行 Hydrate。

服务方式

  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 };
}

请求DTO

 [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 正在发挥作用(它在这里)的事情之后,everyhting 说要使用 '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

我的服务不寻找、忽略并且从不反序列化任何内容。但是对象正在尝试发布!以下是标题:

请求头

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", “地址行 2”:“”, “城市”:“森林湖”, “联系方式”:“1”, “电子邮件”:“nibh.sit.amet@gravida.ca”, “名字”:“阿梅拉”, “家庭电话”:“222-222-2222”, “姓氏”:“空气之心”, “中间名”, “手机”:“1-111-111-1111”, “昵称”:“托马斯”, “状态”:“TN”, “后缀”:“NA”, “工作电话”:“(888)-888-8888”, “邮政编码”:“32549”

看来我无法让内容类型表现出来!我真的不想破解 Jquery、HTTP 和 ServiceStack 来做这么简单的事情。有很多 SO 帖子,人们遇到了类似的问题,更改 $.ajax 函数的 contentType 和 DataType 对他们有用,但在这里不起作用。

谢谢

更新:- jdata 是在 $.ajax 调用中作为数据参数传递的变量,是一个 {} 对象。我做了一个 console.log(jdata) 来验证它实际上是一个对象,而不是被误认为是字符串,或者其他会混淆 $.ajax 的类型。 Firebug 似乎认为它是一个有效的对象,并且它会生成该对象的正确 json 投影。

看起来 $.ajax 正试图将该对象放入 REST 调用的查询字符串中。我能够改变我的服务,以便它不再接受查询字符串中的值。这导致服务方法不触发。

最佳答案

因此,对于服务堆栈,当我使用 application/x-www-form-urlencoded 时,发布到 rest 端点似乎最适合我;字符集=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,这里有一个很好的解释:

servicestack REST API and CORS

关于ServiceStack - 反序列化规则?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14177667/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com