Retrofit 官方文档翻译

Retrofit 官方文档

Retrofit:适用于 Android 和 Java 的类型安全的 HTTP 客户端(原文地址)

介绍

Retrofit 将您的 HTTP API 转换为 Java 接口类。

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

Retrofit 类生成 GitHubService 接口的实现。

Retrofit retrofit = new Retrofit.Builder()
    .baseUrl("https://api.github.com/")
    .build();

GitHubService service = retrofit.create(GitHubService.class);

通过 GithubService 创建的每个 call 都可以向远程 Web 服务器发出同步或异步 HTTP 请求。

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

使用注释来描述 HTTP 请求:

*URL参数替换和查询参数支持
*对象转换为请求正文(例如,JSON,协议缓冲区)
*多部分请求身份和文件上传

API说明

接口方法及其参数的注释表示如何处理请求。

请求方法

每个方法都必须具有提供请求方法和相对 URL 的 HTTP 注释。 有五个内置注释:GET,POST,PUT,DELETE 和 HEAD。资源的相对 URL 在注释中指定。

@GET("users/list")

您也可以在 URL 中指定查询参数。

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

URL 操作

可以使用方法上的替换块和参数动态更新请求URL。 替换块是由{and}包围的字母数字字符串。使用相同的字符串,必须使用 @Path 注释相应的参数。

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

也可以添加多个查询参数。

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

对于复杂的查询参数组合,可以使用 Map。

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

REQUEST BODY

可以指定一个对象用作具有 @Body 注释的 HTTP 请求体。

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

该对象也将使用在 Retrofit 实例上指定的转换器进行转换。如果没有加入转换器,则只能使用 RequestBody 。

FORM ENCODED AND MULTIPART

也可以声明方法发送表单编码和多部分数据。

当方法中存在 @FormUrlEncoded 时,会发送表单编码数据。 每个键值对都使用 @Field 进行注释,其中包含名称和提供该值的对象。

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

当方法中存在 @Multipart 时,会使用多部分请求。部件使用 @Part 注释声明。

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

Multipart 部件使用 Retrofit 的转换器之一,或者可以实现 RequestBody 来处理自己的序列化。

HEADER 操作

您可以使用 @Headers 注释为方法设置静态 header 。

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

请注意,标题不会相互覆盖。 所有名称相同的标题都将包含在请求中。

可以使用@Header注释动态更新请求标头。 必须向@Header提供相应的参数。 如果值为null,则头将被省略。 否则,将调用toString的值,并使用结果。

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

可以使用 OkHttp 拦截器 指定需要添加到每个请求中的标题。

同步 VS 异步

调用实例可以同步或异步地执行。每个实例只能使用一次,但是调用 clone()将创建一个可以使用的新实例。

在 Android 上,回调将在主线程上执行。在 JVM 上,回调将发生在执行 HTTP 请求的同一个线程上。

转换器

默认情况下,Retrofit 只能反序列化 HTTP 身份到 OkHttp 的 ResponseBody 类型,它只能接受 @Body 的 RequestBody 类型。

可以添加转换器来支持其他类型。六个兄弟模块适应流行的序列化库,方便您使用。

[Gson][3]: com.squareup.retrofit2:converter-gson
[Jackson][4]: com.squareup.retrofit2:converter-jackson
[Moshi][5]: com.squareup.retrofit2:converter-moshi
[Protobuf][6]: com.squareup.retrofit2:converter-protobuf
[Wire][7]: com.squareup.retrofit2:converter-wire
[Simple XML][8]: com.squareup.retrofit2:converter-simplexml
Scalars (primitives, boxed, and String): com.squareup.retrofit2:converter-scalars

以下是使用 GsonConverterFactory 类生成使用 Gson 进行反序列化的 GitHubService 接口的实现的示例。

Retrofit retrofit = new Retrofit.Builder()
    .baseUrl("https://api.github.com")
    .addConverterFactory(GsonConverterFactory.create())
    .build();
GitHubService service = retrofit.create(GitHubService.class);

自定义转换器

如果您需要与使用 Retrofit不支持的内容格式(例如YAML,txt,自定义格式)或希望使用不同的库来实现现有格式的 API 进行通信,则可以轻松创建 你自己的转换器 创建一个扩展 Converter.Factory 类,并在构建适配器时传递一个实例。

项目导入

GitHub 提供了 Retrofit 示例和源代码

MAVEN


  com.squareup.retrofit2
  retrofit
  2.2.0

GRADLE

compile 'com.squareup.retrofit2:retrofit:2.2.0'

Retrofit 需要至少 Java 7 或 Android 2.3。

PROGUARD

如果您在项目中使用 ProGuard,请在配置中添加以下行:

# Platform calls Class.forName on types which do not exist on Android to determine platform.
-dontnote retrofit2.Platform
# Platform used when running on Java 8 VMs. Will not be used at runtime.
-dontwarn retrofit2.Platform$Java8
# Retain generic type information for use by reflection by converters and adapters.
-keepattributes Signature
# Retain declared checked exceptions for use by a Proxy instance.
-keepattributes Exceptions

Retrofit 如果使用了 Okio,可以参考 ProGuard 规则。

你可能感兴趣的:(Retrofit 官方文档翻译)