转载 

Retrofit添加header参数的几种方法。

分类:    290人阅读    IT小君  2018-03-14 23:09

(1)使用注解的方式

添加一个Header参数

public interface UserService {    
    @Headers("Cache-Control: max-age=640000")  
    @GET("/tasks")  
    Call<List<Task>> getTasks();  
}  
添加多个Header参数

public interface UserService {    
    @Headers({  
        "Accept: application/vnd.yourapi.v1.full+json",  
        "User-Agent: Your-App-Name"  
    })  
    @GET("/tasks/{task_id}")  
    Call<Task> getTask(@Path("task_id") long taskId);  
}  
(2)使用代码的方式,则需要使用拦截器

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()  
            .header("User-Agent", "Your-App-Name")  
            .header("Accept", "application/vnd.yourapi.v1.full+json")  
            .method(original.method(), original.body())  
            .build();  
  
        return chain.proceed(request);  
    }  
}  
  
OkHttpClient client = httpClient.build();    
Retrofit retrofit = new Retrofit.Builder()    
    .baseUrl(API_BASE_URL)  
    .addConverterFactory(GsonConverterFactory.create())  
    .client(client)  
    .build();  
(3)使用注解的方式,但是Header参数每次提交的都不同,也就是动态的Header

public interface UserService {    
    @GET("/tasks")  
    Call<List<Task>> getTasks(@Header("Content-Range") String contentRange);  
}  
注意:以上都是在Retrofit2.0及以上使用的。

点击广告,支持我们为你提供更好的服务

html5 canvas彩色碎片组合球形旋转动画特效

响应式时尚单品在线商城网站模板

jQuery右端悬浮带返回顶部特效

js+css3抽奖转盘旋转点餐代码

网页设计开发公司网站模板

响应式太阳能能源公司网站模板

现代时尚家具公司网站模板

css鼠标跟随文字模糊特效

html5图标下拉搜索框自动匹配代码

HTML5数字产品服务公司网站模板

canvas炫酷鼠标移动文字粒子特效

css+js实现的颜色渐变数字时钟动画特效

有机水果蔬菜HTML5网站模板

响应式咖啡饮品宣传网站模板

html5 canvas进度条圆环图表统计动画特效

中小型创意设计服务公司网站模板

HTML5现代家居装潢公司网站模板

HTML5 Canvas竖直流动线条背景动画特效

小众时尚单品在线电子商务网站模板

html5 svg夜空中星星流星动画场景特效

点击广告,支持我们为你提供更好的服务
 工具推荐 更多»
点击广告,支持我们为你提供更好的服务