如何使用 RestSharp 調用 WebAPI 接口

REST 是由 Representational State Transfer 這三個單詞前綴合成,這種架構風格在前幾年特別流行,Restful API 的行為規范可以參考: https://docs.microsoft.com/en-us/azure/architecture/best-practices/api-design ,通常 RESTful API 返回的格式為常見的 PlianText, JSON , XML 格式。

RestSharp 是一個開源的 Http 客戶端類庫,非常方便和 RESTful 格式的 Service 進行交互,????的是,這個類庫封裝了 request 請求過程中復雜的細節,而且 RestSharp 支持同步和異步兩種請求模式。

這篇文章將會討論如何使用 RestSharp 去請求 Asp.NET Core 服務。

實現 DefaultController

打開 DefaultController.cs 文件并用下面的代碼進行替換。

using Microsoft.AspNetCore.Mvc;
using System.Collections.Generic;

namespace RESTAPIDemo.Controllers
{
   [Route("api/[controller]")]
   [ApiController]
   public class DefaultController : ControllerBase
   {
       private readonly Dictionary<int, string> authors = new Dictionary<int, string>();
       public DefaultController()
       {
           authors.Add(1, "Joydip Kanjilal");
           authors.Add(2, "Steve Smith");
           authors.Add(3, "Michele Smith");
       }

       [HttpGet]
       public List<string> Get()
       {
           List<string> lstAuthors = new List<string>();
           foreach (KeyValuePair<int,string> keyValuePair in authors)
               lstAuthors.Add(keyValuePair.Value);
           return lstAuthors;
       }

       [HttpGet("{id}", Name = "Get")]
       public string Get(int id)
       {
           return authors[id];
       }

       [HttpPost]
       public void Post([FromBody] string value)
       {
           authors.Add(4, value);
       }

       [HttpPut("{id}")]
       public void Put(int id, [FromBody] string value)
       {
           authors[id] = value;
       }

       [HttpDelete("{id}")]
       public void Delete(int id)
       {
           authors.Remove(id);
       }
   }
}

image.gif

參考上面的 DefaultController 類,可以發現 Action 方法的名字對應著 Http 動詞的 GET,POST,PUT 和 DELETE,為了簡單起見,我使用了 Dictionary 來存取數據,你可以用 瀏覽器 或者 Postman 或者 Fiddler 進行測試,請注意,這里為了方便,我在 Post 方法中使用了硬編碼,實際場景中你可以用自己的方式生成唯一ID。

接下來的章節我們將會學習如何使用 RestSharp 去調用剛才構建的 API 接口。

安裝 RestSharp

要想使用 RestSharp,你可以使用 Visual Studio 2019 中的 NuGet package manager 可視化界面進行安裝,或者通過 NuGet package manager console 命令行輸入如下命令:

Install-Package RestSharp

image.gif

使用 RestSharp 調用 ASP.NET Core API

一旦 RestSharp 成功引用到項目之后,就可以使用它了,首先, 你需要創建 RestClient 實例,下面的代碼展示了如何對 RestClient 進行實例化和初始化操作,要注意的是構造函數中的 url 配置的是 基址,言外之意這不是完整的url。

RestClient client = new RestClient("http://localhost:58179/api/");

image.gif

接下來,你可以傳遞 資源名請求方式 兩個參數來實例化 RestRequest 對象,下面的代碼展示了如何實現。

RestRequest request = new RestRequest("Default", Method.GET);

image.gif

最后,你可以執行 request 請求,再將返回的結果序列化, 最后用一個合適的對象接收,就像下面代碼一樣。

IRestResponse<List<string>> response = client.Execute<List<string>>(request);

image.gif

下面是完整的可供參考的代碼清單。

using RestSharp;
using System;
using System.Collections.Generic;
namespace RESTSharpClientDemo
{
    class Program
    {
        private static RestClient client = new RestClient("http://localhost:58179/api/");

        static void Main(string[] args)
        {
            RestRequest request = new RestRequest("Default",Method.GET);
            IRestResponse<List<string>> response = client.Execute<List<string>>(request);
            Console.ReadKey();
        }
    }
}

image.gif

如果想使用 RestSharp 發送 POST 請求,可以使用如下代碼。

RestRequest request = new RestRequest("Default", Method.POST);
request.AddJsonBody("Robert Michael");
var response = client.Execute(request);

image.gif

RestSharp 可以跨多個 .NET 平臺使用,比如說:Momo,Xarmain,Blazer 等等,這也是它為什么非常流行的原因,而且 RestSharp 支持通過泛型方式獲取結果,這個特性特別 ????,想了解更多 RestSharp 知識,可參考 Github:https://github.com/restsharp/RestSharp

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容