使用ReTrofit做缓存(结合上拉加载和下拉刷新)
1. noCache 不使用缓存,全部走网络
2. noStore 不使用缓存,也不存储缓存
3. onlyIfCached 只使用缓存
4. maxAge 设置最大失效时间,失效则不使用 需要服务器配合
5. maxStale 设置最大失效时间,失效则不使用 需要服务器配合 感觉这两个类似 还没怎么弄清楚,清楚的同学欢迎留言
6. minFresh 设置有效时间,依旧如上
7. FORCE_NETWORK 只走网络
8. FORCE_CACHE 只走缓存
结合推酷和简书看
Cache-Control: no-cache 在请求头中的意思是:不去拿缓存的数据,直接去访问服务器的数据。 在响应头中的意思是:服务器允许客户端缓存,但是必须先验证一下(和 no-store的区别)
Cache-Control: max-age=300 在请求头中表示:第一次访问服务器获取数据之后,300秒之内再访问时,直接走缓存,超过300秒再去请求服务器
在响应头中表示:300秒之内,从服务器的缓存中回给客户端,300秒后从真正的数据中回给客户端
在响应头中,Cache-Control参数的 no-cache,表示客户端仍然可以缓存,但是缓存时要评估下有效性(?)
相应的,在响应头中,no-store,表示客户端一定无法缓存,注意两者区别.
用ReTrofit做缓存时,使用的OkHttp的拦截器,在ReTrofit初始化中进行设置
//构造函数
public WebControl_Retrofit(){
init();
}
public void init() {
Log.d("OkHttp","ReTrofit init");
HttpLoggingInterceptor logging = new HttpLoggingInterceptor();//添加访问网络的日志
logging.setLevel(HttpLoggingInterceptor.Level.BODY);//日志级别
OkHttpClient httpClient = new OkHttpClient(); //缓存路径
File cacheFile = new File(UIUtils.getContext().getCacheDir().getAbsolutePath(), "HttpCache");
Cache cache = new Cache(cacheFile, 1024 * 1024 * 100);//缓存文件为100MB
httpClient.setCache(cache); Interceptor netInterceptor = new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request();
if(!UIUtils.isNetworkReachable(UIUtils.getContext())){//如果网络不可用
request=request.newBuilder()
.cacheControl(CacheControl.FORCE_CACHE)
.build();
Log.d("OkHttp","网络不可用请求拦截");
}else{//网络可用
request = request.newBuilder()
.cacheControl(CacheControl.FORCE_NETWORK)
.build();
Log.d("OkHttp","网络可用请求拦截");
}
Response response = chain.proceed(request);
if(UIUtils.isNetworkReachable(UIUtils.getContext())){//如果网络可用
Log.d("OkHttp","网络可用响应拦截");
response= response.newBuilder()
//覆盖服务器响应头的Cache-Control,用我们自己的,因为服务器响应回来的可能不支持缓存
.header("Cache-Control", "public,max-age=2")
.removeHeader("Pragma")
.build();
}else{
// Log.d("OkHttp","网络不可用响应拦截");
// int maxStale = 60 * 60 * 24 * 28; // tolerate 4-weeks stale
// response= response.newBuilder()
// .header("Cache-Control", "public, only-if-cached, max-stale=" + maxStale)
// .removeHeader("Pragma")
// .build();
}
return response; }
};
httpClient.interceptors().add(netInterceptor);//添加本地缓存拦截器,用来拦截本地缓存
httpClient.networkInterceptors().add(netInterceptor);//添加网络拦截器,用来拦截网络数据
httpClient.interceptors().add(logging); // <-- this is the important line! mRetro = new Retrofit.Builder()
.baseUrl(Web_GlobalConstant.SERVER_URL)
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(retrofit.RxJavaCallAdapterFactory.create())
.client(httpClient)
.build();
}
ReTrofit是根据请求服务器的URL去创建缓存文件,请求的URL不同,所创建的缓存文件也不同,在发起访问服务器请求时,Retrofit根据URL去找对应的缓存,然后返回缓存的数据
刷新和加载更多的思路:让服务器给每一条数据做一个时间戳标记,回过来数据时放在Json里,客户端的请求URL中加一个时间戳参数,下拉刷新时,客户端传时间戳为0,表示请求最新的20条数据(假设以20条为单位),请求后ReTrofit根据URL把最新20条数据缓存起来,以请求朋友圈为例子,那么朋友圈缓存文件里只有一个文件,那就是最新的20条数据,并且永远会这样,把传过来的最后一条数据的时间戳记下来,等到上拉加载时,把这个时间戳参数传过去,然后服务器再把这个时间戳对应数据的之后20条数据回过来,如此循环,这样就能保证数据完整性,上拉加载更多的数据不需要缓存,只缓存最新的20条数据,服务器是以时间倒序存储的数据
做个笔记:static修饰的变量,在应用程序没有完全被清理时,会一直保持引用
这里是我的GitHub地址,里面有我自己做的一些有用的Demo,适合新手学习,欢迎大家star我的项目 https://github.com/gnehsuy
使用ReTrofit做缓存(结合上拉加载和下拉刷新)的更多相关文章
- Vue-上拉加载与下拉刷新(mint-ui:loadmore)一个页面使用多个上拉加载后冲突问题
所遇问题: 该页面为双选项卡联动,四个部分都需要上拉加载和下拉刷新功能,使用的mint-ui的loadmore插件,分别加上上拉加载后,只有最后一个的this.$refs.loadmore.onTop ...
- 使用mescroll实现上拉加载与下拉刷新
现在上拉加载与下拉刷新几乎已经是移动端必备功能之一了,自己实现一个太麻烦,但是好用的插件又非常少.之前看到网上很多人都在用iScroll,于是也尝试用它做了几个DEMO,但或多或少都有一些问题,比如这 ...
- C#构造方法(函数) C#方法重载 C#字段和属性 MUI实现上拉加载和下拉刷新 SVN常用功能介绍(二) SVN常用功能介绍(一) ASP.NET常用内置对象之——Server sql server——子查询 C#接口 字符串的本质 AJAX原生JavaScript写法
C#构造方法(函数) 一.概括 1.通常创建一个对象的方法如图: 通过 Student tom = new Student(); 创建tom对象,这种创建实例的形式被称为构造方法. 简述:用来初 ...
- 你必须了解的RecyclerView的五大开源项目-解决上拉加载、下拉刷新和添加Header、Footer等问题
前段时间做项目由于采用的MD设计,所以必须要使用RecyclerView全面代替ListView.但是开发中遇到了需要实现RecyclerView上拉加载.下拉刷新和添加Header以及Footer等 ...
- vue使用vant-ui实现上拉加载、下拉刷新和返回顶部
vue使用vant-ui实现上拉加载.下拉刷新和返回顶部 vue现在在移动端常用的ui库有vant-ui和mint-ui,上拉加载.下拉刷新和返回顶部也是移动端最基础最常见的功能.下面就用vant-u ...
- 全网最easy的better-scroll实现上拉加载和下拉刷新
前言 移动端页面常见的一种效果:下拉刷新(pulldownrefresh)和上拉加载(pullupload),目的都是为了增强用户的体验效果,因此各种移动端滑动插件也是层出不穷,今天小编也在这里给大家 ...
- 【微信小程序】scroll-view 的上拉加载和下拉刷新
1.在微信小程序中,想到 下拉刷新 和 上拉加载,如果是整个页面都拖动的话,可以在页面配置中,配置 enablePullDownRefresh 和 onReachBottomDistance 然后在 ...
- UITableView与UISearchController搜索及上拉加载,下拉刷新
#import "ViewController.h" #import "TuanGouModel.h" #import "TuanGouTableVi ...
- vue.js移动端app实战4:上拉加载以及下拉刷新
上拉加载以及下拉刷新都是移动端很常见的功能,在搜索或者一些分类列表页面常常会用到. 跟横向滚动一样,我们还是采用better-scroll这个库来实现.由于better已经更新了新的版本,之前是0.几 ...
- 移动端上拉加载,下拉刷新效果Demo
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- MFC下MCI的使用播放音乐
最近研究了一下MFC下的音乐的播放,主要使用了MCI 1.需要包含的库文件 在链接资源里(link)添加库文件VFW32.lib winmm.lib 2.包含的头文件 #include <mms ...
- HYSBZ 1053 反质数
input n 1<=n<=2000000000 output 不大于n的最大反质数 对于任何正整数x,其约数的个数记作g(x).例如g(1)=1.g(6)=4.如果某个正整数x满足:g( ...
- Python基础篇-day4
本节目录: 1.字符编码 2.函数 2.1参数 2.2变量 2.3返回值 2.4递归 2.5 编程范式 2.6 高阶函数 *************************************** ...
- SQLServer 错误: 15404,无法获取有关 Windows NT 组 用户
因做服务器数据库迁移,造成的一系列问题, 1.重启SQL 代理,操作也不可. 然后又进行操作: SQL---------安全性------登录名 中原来的系统用户名前的计算机名更改为现在所用的计算机名 ...
- VBS虚拟键码
1 VK_LBUTTON 鼠标左键 2 VK_RBUTTON 鼠标右键 3 VK_CANCEL Ctrl+Break(通常不需要处理) 4 VK_MBUTTON 鼠标中键 8 VK_BACK Back ...
- CSS3秘笈:第十一章
表格和表单的格式化 1.表格的各种标签提供了许多有用的“钩子”,可以再上面挂CSS样式.如果创建了<th>标签样式,那么每一个列的标题——<th>标签——看起来就有可能与其他的 ...
- PHP中字符串转换为数值 可能会遇到的坑
今天看到一个老外最喜欢的一段代码 <?php $string = 'zero'; $zero = 0; echo ($string == $zero) ? 'Why? Just why?!' : ...
- 贪心+bfs 或者 并查集 Codeforces Round #268 (Div. 2) D
http://codeforces.com/contest/469/problem/D 题目大意: 给你一个长度为n数组,给你两个集合A.B,再给你两个数字a和b.A集合中的每一个数字x都也能在a集合 ...
- Windsock套接字I/O模型学习 --- 第三章
1. WSAAsyncSelect 模型 WSAAsyncSelect 模型比较简单,是为了适应Windows的消息驱动环境而设置的,WSAAsyncSelect 函数自动把套接字设为非阻塞模式.MF ...
- Lua 迭代器
第一种:lua迭代器的实现依赖于闭包(closure)特性 1.1 第一个简单的写法 --迭代器写法 function self_iter( t ) local i = 0 return functi ...