okhttp还是蛮方便的

来源:互联网 发布:关于贼的网络用语 编辑:程序博客网 时间:2024/05/17 23:50

http://blog.csdn.net/u014614038/article/details/51210685

http://blog.csdn.net/u014614038/article/details/51210685

http://blog.csdn.net/u014614038/article/details/51210685






okhttp还是蛮方便的,我比较喜欢的一个就是它支持get请求返回的数据进行缓存,官网介绍得很简单,懂了话用起来确实挺方便的,不懂的话也就比较折腾了,这里简单说一下我的理解与使用小结,不对之处请指出、一起探讨。

使用方法很简单:

[java] view plain copy
 print?在CODE上查看代码片派生到我的代码片
  1. private static final Interceptor REWRITE_CACHE_CONTROL_INTERCEPTOR = new Interceptor() {  
  2.         @Override  
  3.         public Response intercept(Chain chain) throws IOException {  
  4.             Response originalResponse = chain.proceed(chain.request());  
  5.             return originalResponse.newBuilder().removeHeader("Pragma")  
  6.                     .header("Cache-Control", String.format("max-age=%d"10)).build();//设置了缓存时间为10秒  
  7.         }  
  8.     };  
  9.       
  10.     private static String cachedirectory = Environment.getExternalStorageDirectory() + "/lancoo/caches";  
  11.     private static Cache cache = new Cache(new File(cachedirectory), cacheSize);  

[java] view plain copy
 print?在CODE上查看代码片派生到我的代码片
  1. public static Call doGet(RequestParams param, Callback callback) {  
  2.         String url = param.getUrl();  
  3.         int timeout = param.getTimeout();  
  4.         OkHttpClient okHttpClient;  
  5.         OkHttpClient.Builder builder = new OkHttpClient.Builder();  
  6.   
  7.         builder.connectTimeout(timeout, TimeUnit.MILLISECONDS);  
  8.         if (param.isUsecache()) {  
  9.             builder.cache(cache);  
  10.             builder.networkInterceptors().add(REWRITE_CACHE_CONTROL_INTERCEPTOR);  
  11.   
  12.         }  
  13.   
  14.         okHttpClient = builder.build();  
  15.   
  16.         Request request = new Request.Builder()  
  17.                 .url(url).build();  
  18.   
  19.         Call call = okHttpClient.newCall(request);  
  20.         call.enqueue(callback);  
  21.         return call;  
  22.   
  23.     }  


我们将请求返回的数据打印出来:


上面图片的1是点击获取的服务器的数据,获取后断开网络然后继续点击,可以看到2还能获取到数据,说明这是缓存的数据,当到3时,差不多就是十秒的时间,可以看到,获取数据失败了,这时已经去服务器获取数据了,缓存被清空,由于断开网络是无法获取到数据的。


除了通过拦截器控制缓存数据之外,还有一个CacheControl可以控制缓存数据,它有两个方法:


new CacheControl.Builder() .maxAge(0, TimeUnit.SECONDS)//这个是控制缓存的最大生命时间

new CacheControl.Builder().maxStale(365, TimeUnit.DAYS)//这个是控制缓存的过时时间


这个跟上面的控制缓存的时间有什么区别?一开始我也不懂,发现如果.maxAge(0, TimeUnit.SECONDS)设置的时间比拦截器长是不起效果,如果设置比拦截器设置的时间短就会以这个时间为主,我觉得是为了方便控制。.maxStale(365, TimeUnit.DAYS)设置的是过时时间,我觉得okthhp缓存分成了两个来考虑,一个是为了请求时直接拿缓存省流量,一个是为了下次进入应用时可以直接拿缓存。

下面我验证了一下:

设置maxAge为15秒,maxStale40秒,结果如下:

在图1处获取到数据后断开网络,接下来还能获取到缓存数据,到2出退出应用,到3出是重新进入应用,这时还是断开网络的状态,可以看到还能获取到数据,到了4处发现获取不到数据了。
按道理来说在3处已经超过15秒了应该获取不到数据了可是结果还能获取到数据,到了4时已经超过40秒了,于是缓存清空了。
所以可以知道如果两个都设置了的话,maxStale才是决定缓存过时不过时,过时了才会清空掉,如果只设置maxAge,那么超过maxAg的期限才会被情况,感觉两个的作用是一样。


0 0