当前位置: 首页 > news >正文

Android 中 OkHttp 的自定义 Interceptor 实现统一请求头添加

在 Android 中使用 OkHttp 的自定义 Interceptor 实现统一请求头添加是一种高效的方式,可以避免在每个请求中重复设置头部。以下是详细实现步骤:

1. 创建自定义拦截器类

import okhttp3.Interceptor;
import okhttp3.Request;
import okhttp3.Response;
import java.io.IOException;public class HeaderInterceptor implements Interceptor {@Overridepublic Response intercept(Chain chain) throws IOException {// 1. 获取原始请求Request originalRequest = chain.request();// 2. 添加统一请求头(可扩展更多)Request newRequest = originalRequest.newBuilder().header("User-Agent", "MyApp/Android/1.0.0").header("Accept-Language", "zh-CN").header("Authorization", getAuthToken()) // 示例:动态token.header("Custom-Header", "Value")// 添加更多统一头部....build();// 3. 继续执行请求return chain.proceed(newRequest);}// 示例方法:获取动态认证token(根据实际情况实现)private String getAuthToken() {// 这里可以是获取本地存储的tokenreturn "Bearer your_token_here";}
}

2. 在 OkHttpClient 中注册拦截器

// 创建 OkHttpClient 实例
OkHttpClient client = new OkHttpClient.Builder().addInterceptor(new HeaderInterceptor()) // 添加统一头部拦截器// 可选:添加其他拦截器(如日志拦截器).addInterceptor(new HttpLoggingInterceptor().setLevel(HttpLoggingInterceptor.Level.BODY)).build();

3. 使用 OkHttpClient 发送请求(示例)

// 创建请求(无需单独设置统一头部)
Request request = new Request.Builder().url("https://api.example.com/data").build();// 异步执行
client.newCall(request).enqueue(new Callback() {@Overridepublic void onFailure(Call call, IOException e) {// 处理失败}@Overridepublic void onResponse(Call call, Response response) throws IOException {// 处理响应}
});

关键点说明

  1. 拦截器类型选择

    • addInterceptor:应用拦截器,处理非重定向请求
    • addNetworkInterceptor:网络拦截器,处理实际网络请求(包含重定向)
  2. 动态头部处理

    // 示例:根据请求URL动态添加头部
    if (originalRequest.url().toString().contains("/api/secure")) {newRequestBuilder.header("Security-Key", "special_key");
    }
    
  3. 覆盖优先级

    • 拦截器添加的头部 会覆盖 请求中设置的相同名称头部
    • 若需保留请求特定头部,使用以下方式:
      if (!originalRequest.headers().contains("Special-Header")) {newRequestBuilder.header("Special-Header", "default");
      }
      

高级场景处理

1. 需要动态 token 的场景
.header("Authorization", getCurrentToken()) // 实现动态获取// 实现示例
private String getCurrentToken() {return App.getAuthManager().getAccessToken();
}
2. 条件性添加头部
Request.Builder builder = originalRequest.newBuilder();
if (isUserLoggedIn()) {builder.header("User-ID", getUserId());
}
3. 多模块差异化处理
String path = originalRequest.url().encodedPath();
if (path.startsWith("/api/v1")) {builder.header("API-Version", "v1");
} else if (path.startsWith("/api/v2")) {builder.header("API-Version", "v2");
}

完整流程图

发起请求
拦截器处理
是否添加统一头部?
添加预设头部
保留原始头部
执行网络请求
返回响应

通过这种方式,您可以:

  1. 集中管理所有公共请求头
  2. 动态处理认证信息
  3. 根据不同请求条件添加不同头部
  4. 减少代码重复和维护成本

提示:对于敏感信息(如认证 token),建议结合 Android 的安全存储机制(如 EncryptedSharedPreferences)进行存储和获取。

相关文章:

  • Laravel 从版本 5 到 12 每个版本都引入了一些新的特性、改进和弃用的功能
  • Android 获取签名 keystore 的 SHA1和MD5值
  • 前端构建工具(Webpack\Vite\esbuild\Rspack)拆包能力深度解析
  • TC3xx中PFLASH缓存对XCP标定常量的影响
  • 13_算法链与管道
  • 机器学习算法_支持向量机
  • Linux免驱使用PCAN,使用方法以Ubuntu为例
  • 123数字人视频剪辑源码搭建部署/数字人视频创作技术开发
  • 数据结构 学习 栈 2025年6月14日 11点09分
  • 使用Docker安装FFmpeg
  • YOLOv2 训练过程详解:从数据到模型落地的全流程解析
  • Javascript和NodeJS异常捕获对比
  • vim编辑常用命令
  • 零基础RT-thread第二节:按键控制
  • MQTT 和 CoAP物联网通信协议之争:MQTT 与CoAP 深度对比分析
  • 如何编写高效的Prompt:从入门到精通
  • 前端基础知识CSS系列 - 03(em/px/rem/vh/vw)
  • CS144 lab0: warmup
  • Flutter网络请求完全指南:http与Dio库深度解析
  • js调试技巧
  • 做网站需要学php吗/网站seo
  • 动态网站的表单设计/河南最近的热搜事件
  • 如何建设好营销网站/免费私人网站建设
  • 怎么用手机做网站教程/重庆网站推广专家
  • 云南app开发制作/郑州搜索引擎优化公司
  • 网站如何做a b测试/seo网络优化是什么意思