Retrofit提供了两个两种定义HTTP请求头字段的方法即静态和动态。静态头不能改变为不同的请求,头的键和值是固定的且不可改变的,随着程序的打开便已固定。在Retrofit 2.0中,OkHttp 是必须的,并且自动设置为了依赖。这样,我们又可以采用OkHttp添加请求头的方式添加请求头。
动态添加
@Header
String value:默认为"",参数名称
@GET("/")
Call<ResponseBody> query(@Header("Accept-Language") String lang);
@HeaderMap
@GET("/search")
Call<ResponseBody> query(@HeaderMap Ma<String, String> headers);
静态添加
@Headers("Cache-Control: max-age=640000")
@GET("/tasks")
Call<List<Task>> getTasks();
@Headers({
"X-Foo: Bar",
"X-Ping: Pong"
})
@GET("/")
Call(ResponseBody) deleteObject(@Query("id") String id);
OkHttp 请求拦截器
OkHttpClient client = httpClient.build();
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(API_BASE_URL)
.addConverterFactory(GsonConverterFactory.create())
.client(httpClient)
.build(); OkHttpClient.Builder httpClient = new OkHttpClient.Builder(); httpClient.addInterceptor(new Interceptor() { @Override public Response intercept(Interceptor.Chain chain) throws IOException { Request original = chain.request(); Request request = original.newBuilder() .addHeader("Cache-Control", "no-cache") .addHeader("Cache-Control", "no-cache") .method(original.method(), original.body()) .build(); return chain.proceed(request); } } OkHtt请求头通过拦截器添加Header,两种方式的不同 .header(key, val):如果key相同,最后一个val会将前面的val值覆盖 .addHeader(key, val):如果key相同,最后一个val不会将前面的val值覆盖,而是新添加一个Header