Retrofit--使用Retrofit时怎样去设置OKHttp

原创 2016年05月12日 22:22:02

绪论:

之前我们分析了使用Retrofit怎么用OkHttp持久化管理Cookie,今天打算继续跟大家来分享一些关于怎么去设置OKHttp?如果你还不知道怎么持久化管理Cookie,请看这篇文章: Retrofit+OKHttp 教你怎么持久化管理Cookie,好了,废话不多说,开始今天的分享:

大家都知道Retrofit是Square公司基于OkHttp推出的一个高解耦的网络框架,至于为什么又出来一个这个东东,想必可能是觉得使用OKHttp一般都需要自己再包一层吧,当然你也可以不用再自己费劲去封装,因为网上很多大牛前辈已经做了,你可以看鸿洋大神封装的OKHttp, Android 一个改善的okHttp封装库,只要你能想到的,这里面都有,因为我已经用这个做过一个APP了。

切入正题:我们先看一下Retrofit里面都包括那些东西吧:
这里写图片描述
我们可以看到Retrofit里面东西非常少,http包里面的注解的东西,剩下的就这几个类和这几个接口,因为Retrofit把网络请求交给了OkHttp去做,我们来详细介绍一个这个类:

  • Call:
    这个接口主要的作用就是发送一个Http请求,Retrofit的默认请求方式是OKHttpCall,当然你也可以根据自己的业务逻辑自己定义Call。

  • CallAdapter:
    这个接口的主要作用就是将Call对象转化成另一个对象,原谅我的水平有限,没太看懂里面的代码

  • CallBack:
    看接口名想必大家都能看出来,这是回掉接口,里面有两个回调方法
    onResponse()
    onFailure().

  • Converter:
    这个接口主要的作用是将服务器返回数据解析为你所需要的JSON,XML等对象。

  • OkHttpCall:
    OkHttpCall实现了上面的Call接口,通过这个类直接用OkHttp的request去执行网络请求,实现异步,同步请求,接口回调…

  • ServiceMethod:
    这个类主要是用来通过解析注解、传参,将它们封装成Request,然后通过具体的返回值类型,让我们自己配置的工厂生成具体的CallAdapter。

其它的一些类就不一一介绍了,毕竟这篇文章的主题不是源码解析,如果你想从源码的角度去了解Retrofit,我推荐你可以去看这两篇文章:
Retrofit2 完全解析 探索与okhttp之间的关系
Retrofit分析-漂亮的解耦套路
好了,我们看了Retrofit包里面并没有网络请求的部分,因为它是依赖OKHttp实现的一个网络框架,那么有关网络的一部分设置比如cookie的设置、网络超时的设置、请求header设置等等这些我们就该去设置OKHttp。

1.回顾一下之前的持久化管理cookie:

保存本地cookie:

CookieHandler cookieHandler = new CookieManager(new PersistentCookieStore(context),
                CookiePolicy.ACCEPT_ALL);

添加cookieJar:

 .cookieJar(new JavaNetCookieJar(cookieHandler))

2.设置网络超时:
读、写、连接:

.readTimeout(10000, TimeUnit.MILLISECONDS)
                .connectTimeout(10000,TimeUnit.MILLISECONDS)
                .writeTimeout(1000,TimeUnit.MILLISECONDS)

3.设置HttpLoggingInterceptor拦截器:
我们可以设置拦截器来打印网络请求的返回结果:

HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
        logging.setLevel(HttpLoggingInterceptor.Level.BODY);

其中Interceptors的level是可以自行设置的:
注释写的很清楚了,就不废话了

public enum Level {
    /** No logs. */
    NONE,
    /**
     * Logs request and response lines.
     *
     * <p>Example:
     * <pre>{@code
     * --> POST /greeting http/1.1 (3-byte body)
     *
     * <-- 200 OK (22ms, 6-byte body)
     * }</pre>
     */
    BASIC,
    /**
     * Logs request and response lines and their respective headers.
     *
     * <p>Example:
     * <pre>{@code
     * --> POST /greeting http/1.1
     * Host: example.com
     * Content-Type: plain/text
     * Content-Length: 3
     * --> END POST
     *
     * <-- 200 OK (22ms)
     * Content-Type: plain/text
     * Content-Length: 6
     * <-- END HTTP
     * }</pre>
     */
    HEADERS,
    /**
     * Logs request and response lines and their respective headers and bodies (if present).
     *
     * <p>Example:
     * <pre>{@code
     * --> POST /greeting http/1.1
     * Host: example.com
     * Content-Type: plain/text
     * Content-Length: 3
     *
     * Hi?
     * --> END GET
     *
     * <-- 200 OK (22ms)
     * Content-Type: plain/text
     * Content-Length: 6
     *
     * Hello!
     * <-- END HTTP
     * }</pre>
     */
    BODY
  }

4.设置缓存:

  • 开启OKHttp缓存:

    File httpCacheDirectory = new File(UIUtils.getContext().getExternalCacheDir(), "xxx");
    client.setCache(new Cache(httpCacheDirectory,10 * 1024 * 1024));

先获取系统外部存储的路径,”xxx”可以自己命名,文件夹可以在 android/data/<包名>/cache/resposes 看到里面的内容。

  • 设置拦截器(缓存)拦截Request:
Request request = chain.request();
                if (!AppUtil.isNetworkReachable(UIUtils.getContext())) {
                    request = request.newBuilder()
                            .cacheControl(CacheControl.FORCE_CACHE)
                            .url(path).build();
                    UIUtils.showToastSafe("暂无网络");
                }
  • 设置Response:
Response response = chain.proceed(request);
    if(AppUtil.isNetworkReachable(UIUtils.getContext()))

    {
        int maxAge = 60 * 60; // read from cache for 60 minute
        response.newBuilder()
                .removeHeader("Pragma")
                .header("Cache-Control", "public, max-age=" + maxAge)
                .build();
    }

    else

    {
        int maxStale = 60 * 60 * 24 * 7; // tolerate 4-weeks stale
        response.newBuilder()
                .removeHeader("Pragma")
                .header("Cache-Control", "public, only-if-cached, max-stale=" + maxStale)
                .build();
    }

先判断网络,网络好的时候,移除header后添加haunch失效时间为1小时,网络未连接的情况下设置缓存时间为7天。

5.设置通用Header
Retrofit 2.0支持在每个方法的上面添加注解设置头

@Headers("Content-Type: application/json")

很显然这样比较麻烦,那么你可以这样:

通过拦截器来设置头

OkHttpClient httpClient = new OkHttpClient.Builder()  
                .addInterceptor(new Interceptor() {  
                    @Override  
                    public Response intercept(Chain chain) throws IOException {  
                        Request request = chain.request()  
                                .newBuilder()  
                                .addHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8")  
                                .addHeader("Accept-Encoding", "gzip, deflate")  
                                .addHeader("Connection", "keep-alive")  
                                .addHeader("Accept", "*/*")  
                                .addHeader("Cookie", "add cookies here")  
                                .build();  
                        return chain.proceed(request);  
                    }  

                })  
                .build();  

好了,目前用到的就这么多了,如果后期有其他的会再加上,如果有错误的地方或者不合适的地方希望大家多多指正,留言交流,也可以加群交流。

版权声明:本文为博主原创文章,转载请标明出处。

相关文章推荐

Android基于Retrofit2.0 封装的超好用的RetrofitClient工具类(完美结合RxJava)

原文地址 :http://www.jianshu.com/p/29c2a9ac5abf RetrofitClient 基于Retrofit2.0封装的RetrofitClient. 避免重复...

Android 网络框架 Retrofit2.0介绍、使用和封装

前言 时至今日,Android的网络框架不再像之前那么到处都是,随着Google把 HttpClient直接删掉,似乎意味着Android越来越成熟。网络框架中的佼佼者Volley也不再那么光鲜,取...

RxJava+Retrofit+OkHttp 懒人方式使用一

Retrofit+Rxjava+okhttp 懒人方式使用一背景之前学习完Retrofit+Rxjava之后写了一篇关于封装的博客,发出后受到大家的关注以及使用,由于不断的完善之前的项目,所以决定把最...

Retrofit 2.0使用详解,配合OkHttp、Gson,Android最强网络请求框架

Retrofit终于迎来了2.0版本,也修复了老版本的一些bug,这是修复日志,各位可以自己去看看,[https://github.com/square/retrofit/blob/master/CH...

浅谈Retrofit封装-让框架更加简洁易用

尊重他人的劳动成果,转载请标明出处:http://blog.csdn.net/gengqiquan/article/details/52329259, 本文出自:【gengqiquan的博客】不知不觉...

Retrofit 2.0 超能实践(三),轻松实现文件/多图片上传/Json字符串

通过前两篇姿势的入门 Retrofit 2.0 超能实践,完美支持Https传输 Retrofit2.0 完美同步Cookie实现免登录 通过对Retrofit2.0的前两篇的基础入门和案例实践,...

Android实战——Retrofit2的使用和封装

Retrofit2的使用和封装 本篇文章包含以下内容: Retrofit2是什么 Retrofit2工具类的演示(基于Retrofit2工具类的封装) Retrofit2工...

Android基于Retrofit2.0 +RxJava 封装的超好用的RetrofitClient工具类(六)

csdn :码小白 原文地址: http://blog.csdn.net/sk719887916/article/details/51958010 RetrofitClient基于Ret...

Retrofit自定义Converter之StringConverterFactory

之前写过一篇 浅谈Retrofit封装-让框架更加简洁易用 里面采用的是GsonConverterFactory对于retrofit的返回类型是只能有 具体对象、jsonObject、jsonArra...

Android学习笔记--RetrofitCallback封装

RetrofitCallback call.enqueue(new Callback() { @Override public void onRespo...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)