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拦截器中查看。

相关推荐
Pika4 小时前
深入浅出Compose HitTest 机制
android·android jetpack
资深web全栈开发5 小时前
CoI - 组合优于继承:解耦的艺术
android·java·开发语言
冬奇Lab5 小时前
WMS进阶:多窗口模式与显示管理深度解析
android·源码阅读
加农炮手Jinx6 小时前
Flutter for OpenHarmony:web_socket_channel 全平台 WebSocket 通信标准库,从原理到鸿蒙实战(3000字深度解析)
android·前端·网络·websocket·flutter·华为·harmonyos
王码码20356 小时前
Flutter for OpenHarmony:web_socket 纯 Dart 标准 WebSocket 客户端(跨平台兼容性之王) 深度解析与鸿蒙
android·前端·websocket·网络协议·flutter·华为·harmonyos
zh_xuan8 小时前
kotlin runBlocking函数
android·kotlin·协程·runblocking
三少爷的鞋9 小时前
别再 launch(IO) 了:协程线程切换的 3隐藏反模式
android
贤泽10 小时前
Android 15 Lock Task 模式深度分析(第二部分)
android
huohuopro11 小时前
Vue3 Webview 转 Android 虚拟导航栏遮挡问题记录
android·vue
zh_xuan11 小时前
kotlin 挂起函数
android·开发语言·kotlin