随着Android的三方库越来越多,且越发稳定的今天,提高用户体验成了很多Android攻城狮的一个重要课题,Boss们也开始吵着 咋又不兼容性了,打开页面很慢 ...等等的问题突如其来,那今天的话题就围绕着 页面加载很慢 这个问题做一些优化的建议,大神们觉得写的不好,可以多多提些意见!
因客户在使用app时的场景十分复杂,特别在弱网或无网情况下还能给客户带来良好的使用感受,无疑会大大增加用户倾爱度~~,其中最有效的方法就是适当的网络缓存和图片缓存的加入。结合目前主流的网络请求(同门的okhttp 与retrofit) ,因retrofit 也可以使用okhttp的缓存机制,所以第一篇主要来讲okhttp的缓存使用。
1.网络请求缓存的使用场景(仅供参考)
基于服务器是否支持(可参考返回的Response中Header是否有Cache-Control", "max-age等参数来简单判断)
下面这张图是square的javadoc上拔下的,很清楚的解释了Interceptors的作用,在服务器返回的Response不支持缓存时,可以通过重写Interceptors来实现缓存的效果,当然服务器返回的Response中有Cache-Control", "max-age=" 的话,就直接设置 .cache(cache)就可以了。
详细的内容参考文档:https://github.com/square/okhttp/wiki/Interceptors
2.具体使用方法
导入okhttp3库:compile'com.squareup.okhttp3:okhttp:3.6.0'
获取一个okhttpClient(代码如下):
package com.example.zq.lottiedemo;
import android.content.Context;
import android.util.Log;
import java.io.IOException;
import java.util.concurrent.TimeUnit;
import okhttp3.Cache;
import okhttp3.Interceptor;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
/**
* Created by ZQ on 2017/2/6.
*/
public class MyOkHttp {
private static OkHttpClient mOkHttp;
private final static long maxSize = 30 * 1024 * 1024;//最大的缓存空间
private MyOkHttp() {
}
public synchronized staticOkHttpClient newInstance(Context context) {
if (mOkHttp == null) {
//本地缓存的路径和大小
Cache cache = new Cache(context.getCacheDir(), maxSize);
//一些基本设置
mOkHttp = new OkHttpClient.Builder()
//如服务器返回的header中不支持缓存,即可使用网络拦截器,自行添加
.addNetworkInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request();
Log.i("tag", String.format("Sending request %s on %s%n%s",
request.url(), chain.connection(), request.headers()));
Response response = chain.proceed(request);
response = response.newBuilder()
.removeHeader("Pragma")
.removeHeader("Cache-Control")
//cache for two weeks
.header("Cache-Control", "max-age=" + 3600 * 24 * 14)
.build();
return response;
}
})
.cache(cache)
.connectTimeout(20,TimeUnit.SECONDS)
.readTimeout(20,TimeUnit.SECONDS)
.build();
}
return mOkHttp;
}
}