在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,DELETE和HEAD。注解中的參數為請求的相對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自身強大的功能以及擴展性
文章列表