文章出處

SCOTT HANSELMAN 博客上看到一個好東西《Exploring refit, an automatic type-safe REST library for .NET Standard》,他推薦了一個.NET標準1.4 的自動類型安全的REST庫refit。 refit 類似于Java的Retrofit,是一套RESTful架構的.NET客戶端實現,基于特性,提供把REST API返回的數據轉化為(Plain Ordinary C# Object,簡單C#對象),POCO to JSON,網絡請求(POST,GET,PUT,DELETE等)封裝,內部封裝使用HttpClient,前者專注于接口的封裝,后者專注于網絡請求的高效,二者分工協作。我們的應用程序通過 refit請求網絡,實際上是使用 refit接口層封裝請求參數、Header、Url 等信息,之后由 HttpClient完成后續的請求操作,在服務端返回數據之后,HttpClient將原始的結果交給 refit,后者根據用戶的需求對結果進行解析的過程。

例如:

public interface IGitHubApi
{
    [Get("/users/{user}")]
    Task<User> GetUser(string user);
}

定義上面的一個REST API接口。 該接口定義了一個函數 GetUser,該函數會通過HTTP GET請求去訪問服務器的/users/{user}路徑并把返回的結果封裝為User POCO 對象返回。

其中URL路徑中的{user}的值為GetUser函數中的參數 user的取值。

然后通過 RestService 類來生成一個 IGitHubApi 接口的實現,使用HttpClient 調用;

var gitHubApi = RestService.For<IGitHubApi>(https://api.github.com);
var octocat = await gitHubApi.GetUser("octocat");

從上面的示例可以看出, refit使用特性來聲明HTTP請求

  • 支持 URL 參數替換和查詢參數
  • 返回結果轉換為C#對象(返回結果可以為JSON)
  • 支持 Multipart請求和文件上傳

具體使用文檔

函數和函數參數上的特性聲明了請求方式

1、請求方式

每個函數都必須帶有 HTTP特性來表明請求方式和請求的URL路徑。類庫中有5個HTTP注解:GET, POST, PUT,DELETEHEAD。注解中的參數為請求的相對URL路徑

[Get("/users/list")]

在URL路徑中也可以指定URL參數:

[Get("/users/list?sort=desc")]
2、URL處理

請求的URL可以根據函數參數動態更新。一個可替換的區塊為用 {} 包圍的字符串,而函數參數必需用 @AliasAs特性標明,并且特性的參數為 同樣的字符串

[Get("/group/{id}/users")]//注意 字符串id
Task<List<User>> GroupList([AliasAs("id")] int groupId); //注意 AliasAs特性的參數要和前面的字符串一樣 id
還支持查詢參數
[Get("/group/{id}/users")]
Task<List<User>> GroupList([AliasAs("id")] int groupId, [AliasAs("sort")] string sortOrder);

GroupList(4, "desc");
>>> "/group/4/users?sort=desc"
3、請求體(Request Body)

通過[Body]特性可以聲明一個對象作為請求體發送到服務器。

[Post("/users/new")]
Task CreateUser([Body] User user);
對象將被RestService 使用對應的轉換器轉換為字符串或者字節流提交到服務器。
4、FORM ENCODED AND MULTIPART 表單和Multipart

函數也可以注解為發送表單數據和multipart 數據

5、服務器結果轉換為C# 對象

使用RestService 的轉換器把HTTP請求結果(默認為JSON)轉換為C#對象,C#對象通過函數返回值指定

6、添加請求頭

我們可以通過[Headers]來添加請求頭,支持動態的請求頭。

refit是非常強大的,本文通過豐富的示例和對源碼的挖掘,向大家展示了 refit自身強大的功能以及擴展性


文章列表




Avast logo

Avast 防毒軟體已檢查此封電子郵件的病毒。
www.avast.com


arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()