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 ...
随机推荐
- XBMC源代码分析 4:视频播放器(dvdplayer)-解码器(以ffmpeg为例)
XBMC分析系列文章: XBMC源代码分析 1:整体结构以及编译方法 XBMC源代码分析 2:Addons(皮肤Skin) XBMC源代码分析 3:核心部分(core)-综述 本文我们分析XBMC中视 ...
- 9.1、Libgdx的输入处理的配置和查询
(官网:www.libgdx.cn) 有时判断是否支持输入设备是必要的.通常你的游戏不需要支持所有的输入设备.比如你可能不需要加速度计或者罗盘.这时我们需要禁用这些设备保持电量.接下来将教你怎样做. ...
- python判断类型:想知道一个对象(实例或者变量)是什么类型,什么结构的
用type和isinstance 例子: ta={} ta['1']="a" ta={'2':"b"} ta['3']="c" #使用两个函 ...
- Cocos2d中update与fixedUpdate的区别(六)
它如何工作呢? update:和fixedUpdate:方法实际这样工作. Cocos2D将从iOS接口中取得时间间隔(delta)在你的游戏代码执行期间,并且检查fixedUpdate:方法在间隔期 ...
- 写的还不错的专题,android性能优化
http://www.trinea.cn/android/android-performance-demo/
- 关于iOS中几种第三方对XML/JSON数据解析的使用
Json XML 大数据时代,我们需要从网络中获取海量的新鲜的各种信息,就不免要跟着两个家伙打交道,这是两种结构化的数据交换格式.一般来讲,我们会从网络获取XML或者Json格式的数据,这些数据有着特 ...
- 通过COM组件方式实现java调用C#写的DLL文件
转自这里 最近一段时间单位在做一个Web项目,工程师用JAVA语言,需要公用人员信息,统一用户名和密码,原有的平台中是用C#语言开发的,在网上查找解决方法,通过JAVA调用C#的DLL文件实现.网上资 ...
- iOS监听模式系列之通知中心
补充--通知中心 对于很多初学者往往会把iOS中的本地通知.推送通知和iOS通知中心的概念弄混.其实二者之间并没有任何关系,事实上它们都不属于一个框架,前者属于UIKit框架,后者属于Foundati ...
- Android群英传笔记——第四章:ListView使用技巧
Android群英传笔记--第四章:ListView使用技巧 最近也是比较迷茫,但是有一点点还是要坚持的,就是学习了,最近离职了,今天也是继续温习第四章ListView,也拖了其实也挺久的了,list ...
- C++之IO操作
可参考自: C++之标准设备IO操作流 C++之预定义类型IO格式控制 C++之文件IO操作流