Retrofit2.0 添加Header的方法总结

56 篇文章 1 订阅
16 篇文章 0 订阅

一、使用注解
1. 添加单个header

public interface ApiService {
    @Headers("Content-Type: application/javascript")
    @GET("/data")
    Call<List<AddressBean>> getData();
}


2. 添加多个header

public interface ApiService {
    @Headers({
            "Content-Type: application/javascript",
            "User-Agent: YourAgent"
    })
    @GET("/data/{user_id}")
    Call<List<AddressBean>> getData();
}

3. 动态添加header

public interface ApiService {
    @GET("/data")
    Call<List<AddressBean>> getData(@Header("Content-Range") String contentRange);
}


4. 动态添加多个header

@GET("/search")
Call<ResponseBody> list(@HeaderMap Map<String, String> headers);

1. Post添加单个header

@POST("api/sys/getPermissions")
Observable<ResponseBean<PermissionsBean>> getPermissions(@Query("__token") String token);


2.post添加固定的多个header
 

@POST("api/sys/getPermissions")
 @Headers({"Content-Type:application/x-www-form-urlencoded",
            "Authorization:Basic VmJyZjJNU1FxejhBVlhzMmajhETkJV"})
 Observable<TokenBean> getSsoToken();


二、如果要添加全局header,则需要在代码中添加header
 

   /**
     * 请求拦截器
     */
    private class RequestInterceptor implements Interceptor {
        @Override
        public okhttp3.Response intercept(Chain chain) throws IOException {
 
            Request oldRequest = chain.request();
            Request request = oldRequest.newBuilder()
                    .headers(Headers.of(getHeaders()))//注入头信息
                    .build();
            logRequest(request);
            return logResponse(chain.proceed(request));
        }
    }
 
    /**
     * 获取头信息
     */
    private Map<String, String> getHeaders() {
        HashMap<String, String> headersMap = new HashMap<>();
        headersMap.put("Cookie","jeeplus.session.id");
        return headersMap;
    }


————————————————
版权声明:本文为CSDN博主「天兰之珠」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u012693479/article/details/99645085

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 中使用 Retrofit 上传图片可以通过 `@Multipart` 和 `@Part` 注解实现。以下是 Retrofit 2.0 实现图文上传的方法总结: 1. 添加依赖库 在项目的 `build.gradle` 文件中添加以下依赖库: ```groovy implementation 'com.squareup.retrofit2:retrofit:2.9.0' implementation 'com.squareup.retrofit2:converter-gson:2.9.0' implementation 'com.squareup.retrofit2:converter-scalars:2.9.0' ``` 2. 创建 Retrofit 实例 ```java Retrofit retrofit = new Retrofit.Builder() .baseUrl(BASE_URL) .addConverterFactory(GsonConverterFactory.create()) .build(); ``` 3. 创建 API 接口 ```java public interface ApiService { @Multipart @POST("upload") Call<ResponseBody> upload( @Part("description") RequestBody description, @Part MultipartBody.Part file); } ``` 其中,`@Multipart` 注解表示这是一个包含文本和文件的表单;`@POST("upload")` 表示上传的 URL 地址;`@Part("description") RequestBody description` 表示上传的文本参数,`description` 是参数名,可以自己定义;`@Part MultipartBody.Part file` 表示上传的文件参数。 4. 创建请求参数 ```java File file = new File(filePath); RequestBody requestFile = RequestBody.create(MediaType.parse("image/*"), file); MultipartBody.Part body = MultipartBody.Part.createFormData("file", file.getName(), requestFile); RequestBody description = RequestBody.create(MediaType.parse("multipart/form-data"), "description"); ``` 5. 发送网络请求 ```java ApiService apiService = retrofit.create(ApiService.class); Call<ResponseBody> call = apiService.upload(description, body); call.enqueue(new Callback<ResponseBody>() { @Override public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) { // 成功上传后的处理 } @Override public void onFailure(Call<ResponseBody> call, Throwable t) { // 上传失败后的处理 } }); ``` 以上就是 Retrofit 2.0 实现图文上传的方法总结。注意,在 `AndroidManifest.xml` 文件中需要添加网络权限: ```xml <uses-permission android:name="android.permission.INTERNET" /> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值