okhttp关于header修改

在项目开发中,需要和后台定义一些规则,比如一些请求头信息,Content-Type,User-Agent。不能使用默认的,那么就得我们自己配置全局的。

基于okhttp4.0以上版本修改步骤:

创建我们自己的MediaType, create已经被废弃

复制代码
val mediaType= "application/xxxxx-xxxxx".toMediaTypeOrNull()

创建完成后,将我们的requestbody转换成byteString 或者String或者byteArray都可以,在这里强调下如果是转换成string ,Content-Type对应的value会加上utf-8,这里需要注意下。

复制代码
//三种转换方法
  private fun bodyToString(request: RequestBody): String {
        return try {
            val buffer = Buffer()
            if (request != null) request.writeTo(buffer) else return ""
            buffer.readUtf8()
        } catch (e: IOException) {
            "did not work"
        }
    }

    private fun bodyByteString(request: RequestBody): ByteString {
        val buffer = Buffer()
        request.writeTo(buffer)
        return buffer.readByteString()
    }

    private fun bodyByteArray(request: RequestBody): ByteArray {
        val buffer = Buffer()
        request.writeTo(buffer)
        val readUtf8 = buffer.readUtf8()
        return readUtf8.toByteArray()

    }

接下来就简单了

复制代码
// 示例代码
// newFormbodyData 我们自己的body
val newBody= bodyByteString(newFormbodyData).toRequestBody(mediaType)
最后一步就是将得到的请求体放入到我们的request中post方法中

这样我们就完成了content-type的替换,

User-Agent这些信息我们可以直接在request使用addHeader添加即可,这些信息可以在BridgeInterceptor拦截器中查看。

相关推荐
coderlin_2 小时前
BI布局拖拽 (1) 深入react-gird-layout源码
android·javascript·react.js
2501_915918413 小时前
Fiddler中文版全面评测:功能亮点、使用场景与中文网资源整合指南
android·ios·小程序·https·uni-app·iphone·webview
wen's4 小时前
React Native安卓刘海屏适配终极方案:仅需修改 AndroidManifest.xml!
android·xml·react native
编程乐学5 小时前
网络资源模板--基于Android Studio 实现的聊天App
android·android studio·大作业·移动端开发·安卓移动开发·聊天app
没有了遇见7 小时前
Android 通过 SO 库安全存储敏感数据,解决接口劫持问题
android
hsx6667 小时前
使用一个 RecyclerView 构建复杂多类型布局
android
hsx6667 小时前
利用 onMeasure、onLayout、onDraw 创建自定义 View
android
守城小轩7 小时前
Chromium 136 编译指南 - Android 篇:开发工具安装(三)
android·数据库·redis
whysqwhw8 小时前
OkHttp平台抽象机制分析
android
hsx6669 小时前
Android 内存泄漏避坑
android