编程语言
首页 > 编程语言> > C#-放置呼叫在PostMan中起作用,但在RestSharp中不起作用:收到错误的请求

C#-放置呼叫在PostMan中起作用,但在RestSharp中不起作用:收到错误的请求

作者:互联网

我想用Put命令调用一个端点.

在邮递员中

我可以举一个例子https://example.com/customers/106.然后,我添加一个类型为application / json的主体(在raw下).

当我将此主体放置到端点时,我得到200 OK.

我使用的端点需要两个自定义标头和一个内容类型,它们是在标头下创建的.因此,我添加了三个标头:X-AppSecretToken,X-AgreementGrantToken和Content-Type(到application / json).

在RestSharp中

在这里,我使用以下内容. putstr与我在Postman中放置的物体完全相同:

 var restclient = new RestSharp.RestClient("https://example.com");
 var request = new RestRequest("/customers/" + customerId, Method.PUT);
 request.AddHeader("X-AppSecretToken", systemToken);
 request.AddHeader("X-AgreementGrantToken", userToken);
 request.AddHeader("Accept", "application/json");
 request.AddJsonBody(putstr);
 var response = restclient.Execute(request);

现在,当我这样做时,我得到以下响应,这是我正在调用的API中的一个自定义错误:

"{\"message\":\"Error converting value SOME STUFF}}\\\" to type 'eco.rest.Models.Customer'. Path '', line 1, position 605.\",\"errorCode\":\"E00500\",\"developerHint\":\"The JSON payload could not be parsed. The error message should give you a good indication of where the error is located. One common reason for this error is a missing '{' or a '}' in your payload.\",\"logId\":\"123fc6fb4964a141f612ae8ae7571446\",\"httpStatusCode\":400,\"logTime\":\"2018-05-20T21:56:56\"}"

怎么修?

通常,我永远不会问这个问题.如果有人问,我会说:打开Fiddler或类似工具,看看请求有何不同.

我对此有些麻烦,因为它是HTTPS.

当我调试代码时,我根本看不到Fiddler内部的调用.我也安装了查尔斯,但也没有运气.不确定是什么问题.

但是,我认为阅读此书的人可能会提出这个问题.我自己的假设是,我可能以错误的方式添加了标头,JSON主体编码为不同或相似,但我真的不确定如何继续.我希望有人能帮帮忙!

解决方法:

您的putstr值似乎是JSON值.
AddJsonBody会将此JSON值转换为另一个JSON值.

您应该使用原始对象而不是putstr.

标签:restsharp,c-4-0,postman,http,c
来源: https://codeday.me/bug/20191109/2010897.html