拦截器:
可以再数据递交前后进行拦截。
@Test
public void intercepter() {
OkHttpClient okHttpClient = new OkHttpClient.Builder().addNetworkInterceptor(new Interceptor() {
@NotNull
@Override
public Response intercept(@NotNull Chain chain) throws IOException {
System.out.println(chain.request().header("version"));
return chain.proceed(chain.request());
}
}).addInterceptor(new Interceptor() {
@NotNull
@Override
public Response intercept(@NotNull Chain chain) throws IOException {
//前置处理
Request request = chain.request().newBuilder().addHeader("os", "android")
.addHeader("version", "1.0").build();
Response response = chain.proceed(request);
//后置处理
return response;
}
}).build();
Request request = new Request.Builder().url("https://www.httpbin.org/get?a=1&b=2").build();
Call call = okHttpClient.newCall(request);
try {
Response response = call.execute();
System.out.println(response.body().string());
} catch (IOException e) {
e.printStackTrace();
}
}
上述代码可以在request中自动添加操作系统类型和版本号。
其中添加拦截有两种办法:addNetworkInterceptor
和addInterceptor
后者优先执行,前者在后者之后执行。且同级拦截器依据代码顺序执行。
缓存:
存储发送过的请求,若后续请求相同,不需要重复发送,直接依据缓存从服务器取数据即可。
OkHttpClient okHttpClient = new OkHttpClient.Builder()
.cache(new Cache(new File("D:\\desktop\\"), 1024 * 1024));
缓存需要两个参数,一个存缓存文件,一个是存储大小。
Cookie:
用于网站对于连接进的用户进行状态识别:列入已登陆、Vip等身份辨别。
Map<String, List<Cookie>> cookies = new HashMap<>();
OkHttpClient okHttpClient = new OkHttpClient.Builder()
.cookieJar(new CookieJar() {
@Override
public void saveFromResponse(@NotNull HttpUrl httpUrl, @NotNull List<Cookie> list) {
cookies.clear();
cookies.put(httpUrl.host(), list);
}
@NotNull
@Override
public List<Cookie> loadForRequest(@NotNull HttpUrl httpUrl) {
List<Cookie> cookies = CookieTest.this.cookies.get(httpUrl.host());
return cookies == null ? new ArrayList<>() : cookies;
}
})
.build();
主要在okHttpClient 中添加cookie,记录状态后,后续才能继续进行例如登陆状态才能做的事情。
注意事项:
在cookie中两个方法:saveFromResponse
保存连接后获取的cookie列表。loadForRequest
当域名和我们登陆的相同时,才将对应服务器的cookie列表传出去,否则应该返回一个空列表(注意此处不能只返回null,会报错)。
全局的cookie需要用一个列表进行保存,因为一个域名对应一个cookie列表,可以用Map进行存储和取用。