【http3/quic】cronet 已经原生集成在Android内啦!还不快来开开眼!

前情提要

想要在 Android 上使用 http3/quic 协议的网络请求,通常需要使用三方库,例如okcronet

(ps: okhttp3 不支持 http3 哦,最高只支持到 http2,okhttp是内部完全自己实现的http协议,而不是用的系统的)

关于 Http3 协议的简介可以看这里HTTP3/QUIC 时代的来临,能给App带来什么?

前言:cronet是什么

cronetChromium(大家常用的Chrome浏览器的开源版) 中的网络堆栈,是C/C++编写的现代网络引擎,支持Http1\Http2\Http3所有协议,Google将其独立出来,提供了编译好的so文件供使用。其版本号跟随 Chrome 走。

Google 提供的 Cronet 成品仓库

但是 cornet 只是一个较为底层的网络引擎,直接使用起来并不方便,所有了okcronet这个封装库。

现在发车了,坐稳了

旧时代 Android 原生的网络请求?

众所周知,因为Android系统的原生网络请求很辣鸡,所以官方自己都放弃了,安卓developer基本都是依靠着第三方库VolleyokHttp等等过日子的。包括 cronet,也是一个支持新时代Http3协议的三方库罢了。

新时代 Android 原生的网络请求库!

惊奇发现

不多说,我们先看用法:

kotlin 复制代码
// 导入系统包
import android.net.http.HttpEngine


if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R && 
    SdkExtensions.getExtensionVersion(Build.VERSION_CODES.S) >= 7) {
    
    // 构建系统内置的新版本 Http 请求引擎
    val engine = HttpEngine.Builder(application)
        .setEnableQuic(true)
        .setEnableHttp2(true)
        .setEnableBrotli(true)
        .build()
        
    // 发起网络请求
    engine.openConnection("https://xxxx.xxx.xxx")

}

有的同学会说了,"这乍一看,好像没什么特别的啊"。别急,我们来看下 cronet 的原始使用方式:

kotlin 复制代码
// 构建 cronet Http 请求引擎
val engine = CronetEngine.Builder(application)
        .setEnableQuic(true)
        .setEnableHttp2(true)
        .setEnableBrotli(true)
        .build()
        
// 发起网络请求
engine.openConnection("https://xxxx.xxx.xxx")

嘿~完全一模一样!

再点开 HttpEngine 的源码,会发现,所有的方法定义都是一模一样!!😂😂

赶紧写个 demo 把 HttpEngine 的网络代码跑起来看看日志:

less 复制代码
// vivo x100(Android 15) 上的日志
 I  Cronet version: 121.0.6167.71, arch: aarch64
 
// Android 16 模拟器上的日志
 I  Cronet version: 133.0.6876.3, arch: aarch64

嘿!实锤了!!!HttpEngine 就是系统内置的 cronet ❗️。好家伙,Google 这是在搞大事情啊。

但是

但是,不要急,上面可以看到,HttpEngine的使用是有版本限制的!

  • 系统版本必须大于等于 R ,也就是 Api30(Android 10)
  • 同时,R系统的子扩展版本需要大于等于 7

也就是说要 Android 10 的子版本为 7 以上的系统,为了使用安全,还是 Android 11 来界定吧。

然而

作为独立库的 cronet 对于此情况,已经做了适配处理了,一套api就搞定(本身HttpEngine就是cronet 😂)

scss 复制代码
val cronetEngineBuilder = if (isHttpEngineAvailable()) {
    // 如果系统版本满足,就使用 系统内置版本
    HttpEngineNativeProvider(HttpHelper.application).createBuilder()
} else {
    // 其他的就使用 so 库的版本
    NativeCronetProvider(HttpHelper.application).createBuilder()
}

尾声

趋势已来,Http3\QUIC 的时代已经到来了,不论是 cronet 还是原生的 HttpEngine,都是最好的体现。

Android系统的网络引擎摆烂,在多年的情况下,Google终于是捡起来了,把全球亿级用户量、高性能的chrome 网络引擎带了直接带到安卓上,我觉这是个很好的做法,只要chrome还活着,那么这个网络引擎就会一直迭代,减少了内部Android项目的开发成本。

也许以后,Android的网络三方库,都只是对系统库的封装了,类似于iOS一样。

也许以后okhttp会直接使用HttpEngine作为Http3协议的实现。

当然,你也可以使用 okcronet 作为你的选择,以保证所有系统版本的库的一致性。

相关推荐
乌萨奇也要立志学C++5 小时前
【Linux】Ext系列文件系统 从磁盘结构到文件存储的原理剖析
android·linux·缓存·1024程序员节
宋发元6 小时前
IPhone 17 Pro Max拍摄专业画质视频教程
android·gradle·iphone
出门吃三碗饭8 小时前
如何在LLM大语言模型上微调来优化数学推理能力?
android·人工智能·语言模型
shaominjin1239 小时前
Android访问OTG文件全解析:从连接到操作的完整指南Android系统访问U盘的实现机制与操作指南
android
游戏开发爱好者812 小时前
HTTPS 内容抓取实战 能抓到什么、怎么抓、不可解密时如何定位(面向开发与 iOS 真机排查)
android·网络协议·ios·小程序·https·uni-app·iphone
Tom4i14 小时前
Android 系统的进程模型
android
介一安全14 小时前
【Frida Android】基础篇9:Java层Hook基础——Hook构造函数
android·网络安全·逆向·安全性测试·frida
杨筱毅14 小时前
【Android】Compose绘制系统 VS 传统View绘制系统
android
介一安全14 小时前
【Frida Android】基础篇10:Native层Hook基础--普通 Hook
android·网络安全·逆向·安全性测试·frida