Retrofit的Cookie操作方案
Cookie简介
Cookie一般用于后台和客户端数据访问的有效保证,由服务端创建,客户端保存,客户端访问时将Cookie保存在请求数据header里面,服务端收到访问请求后,解析出header的库,对本次请求进行有效的验证
Retrofit + Cookie
移动端网络库一般都是用Retrofit库,Retrofit是对Okhttp的一次很完美的封装,并且可以自定义Okhttp,我们这里使用的方法就是利用拦截器,拦截每一次请求与访问,解析收到的数据,拿到header里面的Cookie,在把Cookie封装到每一帧的请求里面去,本文只是一个方案,更好的处理办法可以依次举一反三:
- 两个拦截器,接收和发送的
- 拦截器添加到OkHttpClient.Builder
接收拦截器
解析Cookie并保存
public class ReceivedCookiesInterceptor implements Interceptor {
@Override
public Response intercept(Interceptor.Chain chain) throws IOException {
Response originalResponse = chain.proceed(chain.request());
if (!originalResponse.headers("Set-Cookie").isEmpty()) {
//解析Cookie
for (String header : originalResponse.headers("Set-Cookie")) {
if(header.contains("JSESSIONID")){
NetClient.COOKIE = header.substring(header.indexOf("JSESSIONID"), header.indexOf(";"));
}
}
}
return originalResponse;
}
}
发送拦截器
添加Cookie到请求头
public class AddCookiesInterceptor implements Interceptor {
@Override
public Response intercept(Chain chain) throws IOException {
final Request.Builder builder = chain.request().newBuilder();
//添加Cookie
if(!TextUtils.isEmpty(NetClient.COOKIE)){
builder.addHeader("Cookie", NetClient.COOKIE);
}
return chain.proceed(builder.build());
}
}
OkHttpClient.Builder添加上面的两个拦截器
OkHttpClient.Builder = okBuilder = (new OkHttpClient.Builder()).connectTimeout(5L, TimeUnit.SECONDS);
okBuilder.addInterceptor(new AddCookiesInterceptor());
okBuilder.addInterceptor(new ReceivedCookiesInterceptor());
最后,就是自己写网络接口,完成Retrofit的封装,转化接口;
举一反三
无论是Cookie还是其他内容,无论是Header还是Body都可以通过拦截器对数据的修改和删除,对网络数据进行修改,比如获取每一帧数据的内容类型、长度(Content-Type),或者解析body,对body中某些标志位做统一处理