Okhttp拦截状态码

需求说明
需要根据返回的数据里面的状态码code做相应的动作;
例如:
	401 ------>> 没有登录 ------>> 提示用户登录
	403 ------>> 被迫下线 ------>> 提示用户当前账号在其他设备上登录,当前设备被迫下线
	403 ------>> 登录过期 ------>> 提示用户重新登录
	......
1.过滤器代码
import okhttp3.Interceptor;
import okhttp3.Request;
import okhttp3.Response;

/**
 * @Description: Token过期检测
 * @Author: geaosu
 * @CreateDate: 2023年03月07日
 */
public class TokenInterceptor implements Interceptor {
    @Override
    public Response intercept(Chain chain) throws IOException {
        Request request = chain.request();
        Response response = chain.proceed(request);
        // 401 无访问权限
        // 403 登录状态过期
        // 700 没有登录,请先登录
        if (response.code() == 401 || response.code() == 403 || response.code() == 700) {
            // 移除之前保存的Token信息
            UserManager.removeUser();
            UserManager.removeToken();
            // 跳转到登录页
            LoginActivity.open(MyApplication.getApplication());
        }
        return response;
    }
}
2.调用
    // GET 请求
    public Call sendGetReqeust(String requestUrl) {
        try {
            if (NetworkUtils.isConnected()) {
                ConnectionPool connectionPool = new ConnectionPool(CONNECTION_POOL_MAX_IDEL, CONNECTION_POOL_KEEP_ALIVE, TimeUnit.MINUTES);
                TrustAllManager trustAllManager = new TrustAllManager();
                OkHttpClient okHttpClient = new OkHttpClient.Builder()
                        .addInterceptor(new TokenInterceptor()) // 添加判断token是否过期的拦截器
                        .connectionPool(connectionPool)
                        .connectTimeout(CONNECT_TIMEOUT, TimeUnit.SECONDS)
                        .writeTimeout(WRITE_TIMEOUT, TimeUnit.SECONDS)
                        .readTimeout(READ_TIMEOUT, TimeUnit.SECONDS)
                        .sslSocketFactory(createTrustAllSSLFactory(trustAllManager), trustAllManager)
                        .hostnameVerifier(createTrustAllHostnameVerifier())
                        .retryOnConnectionFailure(true)
                        .build();
                String token = SPUtils.getInstance().getString(Constants.TOKEN);//sessionId
                Request request = new Request.Builder()
                        .url(requestUrl)
                        .addHeader("token", token)
//                        .addHeader("userToken", SPUtils.getInstance().getString(Constants.HBTOKEN))
//                        .addHeader("appToken", SPUtils.getInstance().getString(Constants.APPTOKEN))
                        .get()
                        .build();
                Call call = okHttpClient.newCall(request);
                return call;
            }
            return null;
        } catch (Exception e) {
            EventBus.getDefault().post(new DataEvent(DataEvent.Type.NET_WORK_ERR, e.toString()));
            return null;
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OkHttp是一个用于处理HTTP请求的开源Java库。它提供了一个拦截器机制,可以在发送请求和接收响应之前对它们进行修改和处理。以下是关于OkHttp拦截器的一些介绍和示例: 1. OkHttp拦截器是一个接口,它有一个方法intercept(Chain chain),该方法接收一个Chain对象作为参数,该对象表示当前的拦截器链。 2. 拦截器链是按照添加顺序执行的,每个拦截器都可以选择将请求传递给下一个拦截器或者直接返回响应。 3. 拦截器可以在请求和响应中添加、修改或删除头信息,也可以重试请求或者记录请求和响应的日志等。 以下是一个简单的OkHttp拦截器示例,它会在请求头中添加一个自定义的User-Agent信息: ```java public class UserAgentInterceptor implements Interceptor { private static final String USER_AGENT_HEADER = "User-Agent"; private final String userAgent; public UserAgentInterceptor(String userAgent) { this.userAgent = userAgent; } @Override public Response intercept(Chain chain) throws IOException { Request request = chain.request(); Request newRequest = request.newBuilder() .header(USER_AGENT_HEADER, userAgent) .build(); return chain.proceed(newRequest); } } ``` 在上面的示例中,我们创建了一个名为UserAgentInterceptor的拦截器,它接收一个User-Agent字符串作为参数。在intercept方法中,我们首先获取当前的请求对象,然后使用Request.Builder添加一个自定义的User-Agent头信息,最后使用chain.proceed方法将请求传递给下一个拦截器或者返回响应。 以下是一个使用上面定义的拦截器的示例: ```java OkHttpClient client = new OkHttpClient.Builder() .addInterceptor(new UserAgentInterceptor("MyApp/1.0")) .build(); ``` 在上面的示例中,我们创建了一个OkHttpClient对象,并使用addInterceptor方法添加了一个UserAgentInterceptor拦截器。这样,在发送请求时,OkHttp会自动调用我们定义的拦截器,并在请求头中添加一个自定义的User-Agent信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值