NoHttp封装--03 缓存
- 1、
Default模式,也是没有设置缓存模式时的默认模式 这个模式实现http协议中的内容,比如响应码是304时,当然还会结合E-Tag和LastModify等头。
StringRequest request = new StringRequest(url, method);
request.setCacheMode(CacheMode.DEFAULT);
- 2、 当请求服务器失败的时候,读取缓存 请求服务器成功则返回服务器数据,如果请求服务器失败,读取缓存数据返回。
StringRequest request = new StringRequest(url, method);
request.setCacheMode(CacheMode.REQUEST_NETWORK_FAILED_READ_CACHE);
- 3、如果发现有缓存直接成功,没有缓存才请求服务器 ImageLoader的核心除了内存优化外,剩下一个就是发现把内地有图片则直接使用,没有则请求服务器。
请求String,缓存String:
StringRequest request = new StringRequest(url, method);
// 非标准Http协议,改变缓存模式为IF_NONE_CACHE_REQUEST_NETWORK
request.setCacheMode(CacheMode.IF_NONE_CACHE_REQUEST_NETWORK);
请求图片,缓存图片:
ImageRequest request = new ImageRequest(url, method);
request.setCacheMode(CacheMode.IF_NONE_CACHE_REQUEST_NETWORK);
- 4、仅仅请求网络 无论如何也只会请求网络,也不支持http 304这种默认行为。
ImageRequest request = new ImageRequest(url, method);
request.setCacheMode(CacheMode.ONLY_REQUEST_NETWORK);
...
- 5、仅仅读取缓存 无论如何仅仅读取缓存,不会请求网络和其它操作。
Request<Bitmap> request = NoHttp.createImageRequest(imageUrl);
request.setCacheMode(CacheMode.ONLY_READ_CACHE);
注意:如果开发者想先得到缓存再请求网络,开发者可以先发起一个仅仅读取缓存的Request,然后发起一个仅仅请求网络的Request,不过本人已经在准备NoHttp2.0了,到时候将会以一个全新的面貌和开发者们见面。
缓存模式支持缓存任何数据,因为NoHttp保存数据是转为byte[],读取数据时是把byte[]转为开发者想要的数据,因此NoHttp的缓存可以支持任何自定义的Request。
服务器端:
@WebServlet("/cache")
public class CacheServlet extends BaseJsonServlet {
private static final long serialVersionUID = 14646L;
public CacheServlet() {
super();
}
@Override
protected String onResponse(HttpServletRequest request, HttpServletResponse response) throws Exception {
System.out.println("返回新的数据");
return "NoHttp是最好用的Android网络框架。";
}
/**
* 服务端本接口的数据是否过期,没有过期则反悔相应头304,如果过期,会重新返回数据
*/
@Override
protected long getLastModified(HttpServletRequest req) {
// 这里主要是告诉http框架我们的数据是否被修改过,或者说是否过期
String path = getServletContext().getRealPath("index.html");
return new File(path).lastModified();
}
}
客户端:
public class CacheActivity extends Activity implements View.OnClickListener {
/**
* 标志请求是一般协议下的
*/
private final int nohttp_what_org = 0x01;
/**
* 标志请求是请求失败时读取缓存
*/
private final int nohttp_what_failed_read_cache = 0x02;
/**
* 标志请求是仅仅读取缓存的
*/
private final int nohttp_what_only_read_cache = 0x03;
/**
* 测试缓存图片
*/
private final int nohttp_what_only_read_cache_image = 0x04;
/**
* 显示请求数据
*/
private TextView mTvResult;
/**
* 显示请求图片
*/
private ImageView mIvImage;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_cache);
findViewById(R.id.btn_request_org_cache).setOnClickListener(this);
findViewById(R.id.btn_request_failed_read_cache).setOnClickListener(this);
findViewById(R.id.btn_request_none_cache_request).setOnClickListener(this);
findViewById(R.id.btn_request_only_read_cache).setOnClickListener(this);
findViewById(R.id.btn_request_failed_read_cache_image).setOnClickListener(this);
mTvResult = (TextView) findViewById(R.id.tv_result);
mIvImage = (ImageView) findViewById(R.id.iv_image_cache);
}
private HttpCallBack<JSONObject> httpCallBack = new HttpCallBack<JSONObject>() {
@Override
public void onSucceed(int what, Response<JSONObject> response) {
JSONObject jsonObject = response.get();
String result = "";
if (what == nohttp_what_org) {
result += "标准协议,";
} else if (what == nohttp_what_failed_read_cache) {
result += "请求失败的时候显示缓存,";
} else if (what == nohttp_what_only_read_cache) {
result += "没有缓存时请求服务器,";
}
result += "是否来自缓存:" + response.isFromCache() + "\n数据:";
result += jsonObject.getString("data");
mTvResult.setText(result);
}
@Override
public void onFailed(int what, String url, Object tag, Exception exception, int responseCode, long networkMillis) {
}
};
private HttpCallBack<Bitmap> imageHttpCallBack = new HttpCallBack<Bitmap>() {
@Override
public void onSucceed(int what, Response<Bitmap> response) {
if (what == nohttp_what_only_read_cache_image) {
Bitmap bitmap = response.get();
mIvImage.setImageBitmap(bitmap);
mTvResult.setText("是否来自缓存:" + response.isFromCache());
}
}
@Override
public void onFailed(int what, String url, Object tag, Exception exception, int responseCode, long networkMillis) {
}
};
@Override
public void onClick(View v) {
String url = "http://192.168.1.116/HttpServer/news";
Request<JSONObject> request = new FastJsonRequest(url);
if (v.getId() == R.id.btn_request_org_cache) {
// 一般请求,走http标准协议
url = "http://192.168.1.116/HttpServer/cache";
request = new FastJsonRequest(url);
request.setCacheMode(CacheMode.DEFAULT);// DEFAULT表示走Http标准协议,默认就是,这里可以不用设置
CallServer.getInstance().add(this, request, httpCallBack, nohttp_what_org, true, false, true);
} else if (v.getId() == R.id.btn_request_failed_read_cache) {
// 请求失败的时候返回缓存
request.setCacheMode(CacheMode.REQUEST_FAILED_READ_CACHE);// REQUEST_FAILED_READ_CACHE表示走请求失败的时候读取缓存
CallServer.getInstance().add(this, request, httpCallBack, nohttp_what_org, true, false, true);
} else if (v.getId() == R.id.btn_request_none_cache_request) {
// 如果没有缓存才去请求服务器,否则使用缓存
request.setCacheMode(CacheMode.IF_NONE_CACHE_REQUEST);// IF_NONE_CACHE_REQUEST表示没有缓存的时候去请求服务器
CallServer.getInstance().add(this, request, httpCallBack, nohttp_what_org, true, false, true);
} else if (v.getId() == R.id.btn_request_only_read_cache) {
// 仅仅请求缓存,不请求服务器
url = "http://192.168.1.116/HttpServer/only";
request = new FastJsonRequest(url);
request.setCacheMode(CacheMode.ONLY_READ_CACHE);// ONLY_READ_CACHE表示仅仅请求缓存,不请求服务器
CallServer.getInstance().add(this, request, httpCallBack, nohttp_what_org, true, false, true);
} else if (v.getId() == R.id.btn_request_failed_read_cache_image) {
// 如果没有缓存才去请求服务器,否则使用缓存,缓存图片演示,这一点非常适合封装一个自己的Imageloader是来使用
String imageUrl = "http://gtb.baidu.com/HttpService/get?p=dHlwZT1pbWFnZS9qcGVnJm49dmlzJnQ9YWRpbWcmYz10YjppZyZyPTMwMjEwODc5MTEsMTQxMDg4MDEwNgAAAA==";
Request<Bitmap> imageRequest = NoHttp.createImageRequest(imageUrl);
imageRequest.setCacheMode(CacheMode.IF_NONE_CACHE_REQUEST);
CallServer.getInstance().add(this, imageRequest, imageHttpCallBack, nohttp_what_only_read_cache_image, true, false, true);
}
}
}


NoHttp封装--03 缓存的更多相关文章
- NoHttp封装--03 cookie
NoHttp请求自动维持Cookie: 1.支持Session.Cookie.临时Cookie的位置. 2.支持App重启.关机开机后继续持久化维持. 3.提供了接口,允许开发者监听Coo ...
- Android 框架修炼-自己封装双缓存管理框架库
一.概述 Android开发中,网络请求是很重要的一部分,而缓存网络请求来的图片或者响应结果字符串或者结果流,既可以省流量,同时也可以帮助我们 解决无网或弱网情况下加载情况,当然也可以提升程序性能效率 ...
- Python网络编程03 /缓存区、基于TCP的socket循环通信、执行远程命令、socketserver通信
Python网络编程03 /缓存区.基于TCP的socket循环通信.执行远程命令.socketserver通信 目录 Python网络编程03 /缓存区.基于TCP的socket循环通信.执行远程命 ...
- # 095 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 03 封装总结 01 封装知识点总结
095 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...
- NoHttp封装--01
NoHttpActivity public class NoHttpActivity extends Activity implements View.OnClickListener { privat ...
- react native之封装离线缓存框架
请求数据=>本地有无缓存+缓存数据是否过期 =>可用 =>不可用 将代码封装成一个DataStore.js文件, 这里面主要提供:从本地获取数据,从网络获取数据,创建本地时间戳,请求 ...
- Ajax的封装03
一.Ajax 1.原理:基于http协议的 内置对象:XMLHttpRequest 发起请求 那会相应 步骤: var xhr=new XMLHttpRequest(); // 请 ...
- NoHttp封装--07 自定义异步任务框架
MainActivity: public class MainActivity extends Activity implements View.OnClickListener { .... @Ove ...
- NoHttp封装--05 文件下载
xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:la ...
随机推荐
- 水晶报表中"已达到系统管理员配置的最大报表处理作业数限制"错误的处理
错误描述:用水晶报表做报表时当多次打开报表后会经常会出现"已达到系统管理员配置的最大报表处理作业数限制. "的错误. 1.自身的问题:用完CrystalDecisions.Crys ...
- R-- Dplyr包
Dplyr 包应用 1. 筛选 filter() 按照给定的逻辑判断选择出合适的数据子集 fliter(data,year==2015,month==1) 支持对同一对象的任意条件组合 fliter( ...
- Leetcode_123_Best Time to Buy and Sell Stock III
本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/43740415 Say you have an array ...
- sharedpreferences如何保存对象
昨天做了一个搜索历史的功能,然后根据搜索的历史可以调回到上一个页面,这里涉及到一个用sharedpreferences保存对象的问题,sharedpreferences是不能够直接保存对象的,我们需要 ...
- MT6575 充电流程
1,目前充电主要包括Power Off Charging(关机充电) .IPO Charging(休眠充电)和 OS Charging(开机充电) 三个部分 2,Power Off Charging ...
- Android Bootloader LittleKernel的两篇文章
Android 开发之 ---- bootloader (LK) LK是什么 LK 是 Little Kernel 它是 appsbl (Applications ARM Boot Loader)流程 ...
- SQL 是一门美丽的语言 她来自艺术
有一种语言可以从诞生一直活跃到现在,有一个梦想从南四楼蔓延到北五楼再走向世界,有一种坚持可以从懵懂年少成长为干练成熟,有一本书可以温暖心灵彼岸,与数据库抨击撞出火花,有一个系统足以让你忘 ...
- cocos2d-x 控制台输出日志
在2dx中用CCLog输出日志,但是在vs的控制台中由于信息很多,很难发现.可以用下面方法,会重新启动一个黑色的控制台来输出日志 修改main.c文件,如下: #include "main. ...
- JVM学习--(二)内存模型、可见性、指令重排序
我们将根据JVM的内存模型探索java当中变量的可见性以及不同的java指令在并发时可能发生的指令重排序的情况. 内存模型 首先我们思考一下一个java线程要向另外一个线程进行通信,应该怎么做,我们再 ...
- SQL语言逻辑执行顺序
SQL语言逻辑执行顺序 2012-12-18 16:18:13 分类: 数据库开发技术 查询的逻辑执行顺序 FROM < left_table> ON < join_conditio ...