• 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 缓存的更多相关文章

  1. NoHttp封装--03 cookie

    NoHttp请求自动维持Cookie:   1.支持Session.Cookie.临时Cookie的位置.   2.支持App重启.关机开机后继续持久化维持.   3.提供了接口,允许开发者监听Coo ...

  2. Android 框架修炼-自己封装双缓存管理框架库

    一.概述 Android开发中,网络请求是很重要的一部分,而缓存网络请求来的图片或者响应结果字符串或者结果流,既可以省流量,同时也可以帮助我们 解决无网或弱网情况下加载情况,当然也可以提升程序性能效率 ...

  3. Python网络编程03 /缓存区、基于TCP的socket循环通信、执行远程命令、socketserver通信

    Python网络编程03 /缓存区.基于TCP的socket循环通信.执行远程命令.socketserver通信 目录 Python网络编程03 /缓存区.基于TCP的socket循环通信.执行远程命 ...

  4. # 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封装 ...

  5. NoHttp封装--01

    NoHttpActivity public class NoHttpActivity extends Activity implements View.OnClickListener { privat ...

  6. react native之封装离线缓存框架

    请求数据=>本地有无缓存+缓存数据是否过期 =>可用 =>不可用 将代码封装成一个DataStore.js文件, 这里面主要提供:从本地获取数据,从网络获取数据,创建本地时间戳,请求 ...

  7. Ajax的封装03

    一.Ajax   1.原理:基于http协议的     内置对象:XMLHttpRequest 发起请求 那会相应     步骤: var xhr=new XMLHttpRequest(); // 请 ...

  8. NoHttp封装--07 自定义异步任务框架

    MainActivity: public class MainActivity extends Activity implements View.OnClickListener { .... @Ove ...

  9. NoHttp封装--05 文件下载

    xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:la ...

随机推荐

  1. 类模板语法知识体系梳理(包含大量常犯错误demo,尤其滥用友元函数的错误)

    demo 1 #include <iostream> #include <cstdio> using namespace std; //template <typenam ...

  2. UVa - 116 - Unidirectional TSP

    Background Problems that require minimum paths through some domain appear in many different areas of ...

  3. markdown简易快速的编辑格式(易读易写)

    实现简单快速书写,格式指定简便.易读易写 讲解http://wowubuntu.com/markdown/ 简单使用的讲解:http://www.ituring.com.cn/article/23 代 ...

  4. Hbase replication操作

    1.修改hbase-site.xml文件 <property>  <name>hbase.replication</name>  <value>true ...

  5. Oracle ERP系統借贷关系表

    系统分步骤产生的分录: 1)库存模块作接收时产生的分录为: 借:材料采购 (采购单价X订单数量) 贷:应计负债 (采购单价X订单数量) 2)库存模块作检验入库时产生的分录为: 系统产生的分录分别为: ...

  6. rails将类常量重构到数据库对应的表之后记

    怎么还有啊!别急,有强迫症的人伤不起!有点小事没说完感觉痒痒的:就是如果表payment_types经常变动该怎么办?每次都要关闭rails网页服务器,然后重启吗?那也太麻烦鸟,最终的解决方案是,在O ...

  7. CentOS6.4下安装Nginx1.12.2

    1.安装GCC安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装 yum install gcc-c++ 2.安装PCRE-devel PCR ...

  8. Android studio 项目(Project)依赖(非Module)

    Android studio 项目(Project)依赖(非Module) 0. 前言 对于Module 级别的依赖大家都知道,今天说下Android Studio下的项目依赖. 场景: A Proj ...

  9. 用eclipse怎样将本地的项目打成jar包上传到maven仓库

    使用maven的项目中,有时需要把本地的项目打成jar包上传到mevan仓库. 操作如下: 前提:pom文件中配置好远程库的地址,否则会报错 1.将maven 中的settings文件配置好用户名和密 ...

  10. 检查Json格式工具

    在线JSON校验格式化工具(Be JSON) 地址:http://www.bejson.com/