retrofit2获取响应头信息

xiaoxiao2025-04-29  12

前言 最近几天晚上时候,一直在修改自己前一段时间写的下载工具。想着把它变成开源库造福大家。原本,以为是很简单的事。结果在下载文件格式哪里,博主陡然发现! 以前自己用的时候下载文件格式自己是知道的。所以,命名时候也就one.apk ,two.jpeg。这在个人使用的时候 完全不是问题。但如果变成开源库,这个就很影响逼格了!!!。开源库已经写好!!!Android下载库

确定下载格式

解析下载链接,如果包含 .apk 之类的 ,就将 “/” 到格式之间的取下来,作为文件名 包含格式。 例如下面这个:就应该截取为 201809281641cj0928.apk 但是好多下载链接 ,是没有 .文件格式 的。这时候 ,我们可以获取响应头里面的 “Content-Disposition” 它里面有一个 filename 属性,我们这时候 把filename的值当做文件名就行了。 但是,好多时候后台 如果 不返回这东西怎么办?我们还可以根据 Content-Type来确定文件格式,就是不太准确。 Content-Type: application/vnd.android.package-archive。因为,有时候 后面这个值对应好几个文件格式,。。。。

上面都是题外话,这里是本文重点

获取response.header 响应头

这个就是本文的重点了。博主用的是retrofit2 ,而retrofit2 网络活动还是调用了okhttp3 。 所以,获取响应头的方式有两种:

我们可以给okhttp添加拦截器来获取response ,这样就可以取到响应头了。这个需要我们在创建OkHttpClient OkHttpClient okHttpClient = new OkHttpClient.Builder().connectTimeout(3, TimeUnit.SECONDS).addInterceptor(new DownLoadInterceptor(downLoadBean)).build(); 调用.addInterceptor()方法。 /** * 下载进度拦截器 在okhttp客户端初始化时候添加进去 * 创建时间 2018/9/4 * @author plani */ public class DownLoadInterceptor implements Interceptor { private DownLoadBean downLoadBean; public DownLoadInterceptor(DownLoadBean downLoadBean) { this.downLoadBean = downLoadBean; } @Override public Response intercept(Chain chain) throws IOException { //获取到response Response response = chain.proceed(chain.request()); //打印响应头 Zprint.log(this.getClass(), "响应头", response.headers().toString()); //得到Response 对它的response 进行包装 用我们自己定义的DownLoadResponseBody return response.newBuilder().body(new DownLoadResponseBody(downLoadBean, response.body())).build(); } }

关键代码呢 就是Response response = chain.proceed(chain.request()); 获取response

直接在retrofit返回结果哪里调用 raw()方法。特别注意 这是retrofit2的Response,不是okhttp3的! @Streaming @GET /* Call<T> 里面的泛型T 不能是 okhttp3.Response 。 可以是 retrofit2.Response<T> ,但是T不能为okhttp3.Response */ Call<ResponseBody> test(@Url String url); Call<ResponseBody> call = headerTest.test("https://ccl-cloud.oss-cn-beijing.aliyuncs.com/201809281641cj0928.apk"); try { //这是同步 异步的话 类似 Response response = call.execute(); System.out.println(" 响应头 "+response.raw().headers()); } catch (IOException e) { e.printStackTrace(); }

3.通常来说,我们的retrofi都和Rxjava一起用。这种情况下是这样的

@Streaming @GET /* Observable<T> 里面的泛型T 不能是 okhttp3.Response 。 可以是 retrofit2.Response<T> ,但是T不能为okhttp3.Response */ Observable<Response<ResponseBody>> testRxjava(@Url String url);

rxjava 取出 这里要注意 retrofit创建时候添加转化器.addCallAdapterFactory(RxJava2CallAdapterFactory.create())

headerTest.testRxjava("https://下载链接/201809281641cj0928.apk").subscribeOn(Schedulers.newThread()) .subscribe(new Observer<Response<ResponseBody>>() { @Override public void onSubscribe(Disposable d) { } @Override public void onNext(Response value) { //这下面两种都可以 System.out.println(" 响应头 two "+value.headers().toString()); System.out.println(" 响应头 two "+value.raw().headers().toString()); } @Override public void onError(Throwable e) { } @Override public void onComplete() { } } );

总结

上面的2 和3 ,我总结的就是 不管是Call 还是Observable也好 ,泛型不能和 okhttp3.Response有关,即便是泛型的泛型 也不行。 如果有不懂的,可以关注我的公众号 “知我饭否” 向我留言。我也会每天更新一些文章,有兴趣的可以扫描下方的二维码

转载请注明原文地址: https://www.6miu.com/read-5029415.html

最新回复(0)