Android中Retrofit的簡要介紹

今天小編就爲大家分享一篇關於Android中Retrofit的簡要介紹,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

Retrofit

A type-safe HTTP client for Android and Java
適用於Java和Android的安全的HTTP客戶端

Retrofit是一個可用於Android和Java的網絡庫,使用它可以簡化我們的網絡操作,提高效率和正確率。它將請求過程和底層代碼封裝起來只暴露我們業務中的請求和返回數據模型。

public interface GitHubService {
 @GET("users/{user}/repos")
 Call<List<Repo>> listRepos(@Path("user") String user);
}

@這是一個Retrofit將Rest API(服務端post或get請求)轉換爲Java接口的例子

每一個由接口返回的Call對象都可以與遠程web服務端進行同步或者異步的HTTP請求通信。例如:

Call<List<Repo>> repos = service.listRepos("octocat");

爲什麼選擇Retrofit

AsyncHttp ,Volley和Retrofit的對比

Retrofit中的註解

Retrofit使用註解來描述HTTP請求

請求方式

每一個請求必須指定http請求相對應的url註解和請求方式(內置5種請求方式註解:GET、POST、PUT 、DELETE、HEAD)

@GET("users/list")

也可以將參數跟在後面

@GET("users/list?sort=desc")

URL操作

一個請求的URL的參數可以通過{}包裹快來動態替換,然後在相應的@Path參數中進行賦值。

@GET("group/{id}/users")
Call<List<User>> groupList(@Path("id") int groupId);

例如這個{id}在groupList請求中的@Path(“id”) int groupId來對應賦值。

也可以使用@Query給groupList請求方法動態添加其他請求參數

@GET("group/{id}/users")
Call<List<User>> groupList(@Path("id") int groupId, @Query("sort") String sort);

如果是比較多的請求參數,我們可以使用Map來構建

@GET("group/{id}/users")
Call<List<User>> groupList(@Path("id") int groupId, @QueryMap Map<String, String> options);

請求的Body

能夠通過@Body註解來指定一個方法作爲HTTP請求主體

@POST("users/new")
Call<User> createUser(@Body User user);

這個參數對象會被Retrofit實例中的converter進行轉化。如果沒有給Retrofit實例添加任何converter的話則只有RequestBody可以作爲參數使用。

form encode 和 multipart

方法也可以通過聲明來發送form-encoded和multipart類型的數據。

可以通過@FormUrlEncoded註解方法來發送form-encoded的數據。每個鍵值對需要用@Filed來註解鍵名,隨後的對象需要提供值。

@FormUrlEncoded
@POST("user/edit")
Call<User> updateUser(@Field("first_name") String first, @Field("last_name") String last);

也可以通過@Multipart註解方法來發送Mutipart請求。每個部分需要使用@Part來註解。

@Multipart@PUT("user/photo")
Call<User> updateUser(@Part("photo") RequestBody photo, @Part("description") RequestBody description);

多個請求部分需要使用Retrofit的converter或者是自己實現 RequestBody來處理自己內部的數據序列化

頭部操作

可以通過使用@Headers註解來設置請求靜態頭。

@Headers("Cache-Control: max-age=640000")
@GET("widget/list")
Call<List<Widget>> widgetList();
@Headers({
  "Accept: application/vnd.github.v3.full+json",
  "User-Agent: Retrofit-Sample-App"
})
@GET("users/{username}")
Call<User> getUser(@Path("username") String username);

注意的是頭部參數並不會相互覆蓋,同一個名稱的所有頭參數都會被包含進請求裏面。

當然你可以通過 @Header 註解來動態更新請求頭。一個相應的參數必須提供給 @Header 註解。如果這個值是空(null)的話,那麼這個頭部參數就會被忽略。否則的話, 值的 toString 方法將會被調用,並且使用調用結果。

@GET("user")
Call<User> getUser(@Header("Authorization") String authorization)

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章