Retrofit的Cookie操作方案

Cookie简介

Cookie一般用于后台和客户端数据访问的有效保证,由服务端创建,客户端保存,客户端访问时将Cookie保存在请求数据header里面,服务端收到访问请求后,解析出header的库,对本次请求进行有效的验证

移动端网络库一般都是用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中某些标志位做统一处理

你可能感兴趣的:(android)