RestSharp JSON การโพสต์พารามิเตอร์


141

ฉันกำลังพยายามโทรหา REST ขั้นพื้นฐานมากไปยัง MVC 3 API ของฉันและพารามิเตอร์ที่ฉันส่งผ่านนั้นไม่ได้ผูกกับวิธีการดำเนินการ

ไคลเอนต์

var request = new RestRequest(Method.POST);

request.Resource = "Api/Score";
request.RequestFormat = DataFormat.Json;

request.AddBody(request.JsonSerializer.Serialize(new { A = "foo", B = "bar" }));

RestResponse response = client.Execute(request);
Console.WriteLine(response.Content);

เซิร์ฟเวอร์

public class ScoreInputModel
{
   public string A { get; set; }
   public string B { get; set; }
}

// Api/Score
public JsonResult Score(ScoreInputModel input)
{
   // input.A and input.B are empty when called with RestSharp
}

ฉันทำอะไรบางอย่างหายไปหรือเปล่า

คำตอบ:


211

คุณไม่จำเป็นต้องทำให้ร่างกายเป็นอนุกรม แค่ทำ

request.RequestFormat = DataFormat.Json;
request.AddBody(new { A = "foo", B = "bar" }); // uses JsonSerializer

หากคุณต้องการให้ POST params แทน (ซึ่งยังคงจับคู่กับโมเดลของคุณและมีประสิทธิภาพมากขึ้นเนื่องจากไม่มีการจัดลำดับเป็น JSON) ทำสิ่งนี้:

request.AddParameter("A", "foo");
request.AddParameter("B", "bar");

4
ทั้งสอง วิธีที่สองนั้นเร็วกว่ามาก
Wesley Tansey

4
คุณสามารถทำได้เช่นAddObject(new { A = "foo", B = "bar" })กันซึ่งใช้คุณสมบัติของวัตถุและแปลงเป็นพารามิเตอร์
John Sheehan

62
สำหรับผู้ที่ต้องการ jsonize ตัวเอง:request.AddParameter("text/json", body, ParameterType.RequestBody);
Kyle Patterson

1
@KylePatterson คุณสามารถใช้ ISerializer ของคุณเองและตั้งค่า RestClient.JsonSerializer เพื่อใช้งานได้
John Sheehan

2
มีrequest.AddBody(new ...ตัวอย่างparantheses ที่ล้าสมัยหนึ่งรายการในตัวอย่างแรกของคุณ
เบนจามิน

54

ใน RestSharp เวอร์ชันปัจจุบัน (105.2.3.0) คุณสามารถเพิ่มวัตถุ JSON ไปยังเนื้อความคำขอด้วย:

request.AddJsonBody(new { A = "foo", B = "bar" });

เมธอดนี้ตั้งค่าชนิดเนื้อหาเป็น application / json และทำให้อ็อบเจ็กต์เป็นอนุกรมสตริง JSON


1
วิธีแนบไฟล์กับคำขอนี้
OPV

1
คุณตั้งชื่อวัตถุอย่างไร เช่น. หากคุณต้องการส่ง "รายละเอียด": {"พิเศษ": "สิ่ง"}?
mdegges

@OPV คุณสามารถเพิ่มไฟล์ลงในคำขอเช่นนี้: request.AddFile (pathToTheFile);
Chris Morgan

1
@mdegges หากคุณใช้คลาสที่ไม่ระบุตัวตนเพื่อให้ JSON มีลักษณะเหมือนตัวอย่างการตั้งค่า RestSharp ของคุณขอสิ่งนี้: var client = new RestSharp.RestClient("http://your.api.com"); var request = new RestSharp.RestRequest("do-something", Method.POST); var body = new {details = new {extras = "stuff"}}; request.AddJsonBody(body); var response = client.Execute(request);
Chris Morgan

43

นี่คือสิ่งที่ใช้งานได้สำหรับฉันในกรณีของฉันมันเป็นโพสต์สำหรับคำขอเข้าสู่ระบบ:

var client = new RestClient("http://www.example.com/1/2");
var request = new RestRequest();

request.Method = Method.POST;
request.AddHeader("Accept", "application/json");
request.Parameters.Clear();
request.AddParameter("application/json", body , ParameterType.RequestBody);

var response = client.Execute(request);
var content = response.Content; // raw content as string  

ร่างกาย :

{
  "userId":"sam@company.com" ,
  "password":"welcome" 
}

2
คุณแทรกเนื้อหาลงในรหัส c # ได้อย่างไร as string body = "{" userId ":" sam@company.com "," รหัสผ่าน ":" welcome "}"; ไม่ทำงาน, ไม่เป็นผล.
Kynao

1
คุณควรใช้ "" แทน "string body = @" {"" userid "", ... "
Vitaly Ascheulov

7

หวังว่านี่จะช่วยใครซักคน มันใช้งานได้สำหรับฉัน -

RestClient client = new RestClient("http://www.example.com/");
RestRequest request = new RestRequest("login", Method.POST);
request.AddHeader("Accept", "application/json");
var body = new
{
    Host = "host_environment",
    Username = "UserID",
    Password = "Password"
};
request.AddJsonBody(body);

var response = client.Execute(request).Content;

ดูเหมือนว่าrequest.AddHeader("Accept", "application/json");เป็นคำตอบที่ถูกต้อง
Bimal Poudel

0

หากคุณมีListวัตถุคุณสามารถทำให้เป็นอนุกรมกับ JSON ดังต่อไปนี้:

List<MyObjectClass> listOfObjects = new List<MyObjectClass>();

จากนั้นใช้addParameter:

requestREST.AddParameter("myAssocKey", JsonConvert.SerializeObject(listOfObjects));

และคุณจะต้องตั้งค่ารูปแบบคำขอเป็นJSON:

requestREST.RequestFormat = DataFormat.Json;
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.