登录

去注册 忘记密码?

登录

注册

去登录

  • 扫码关注公众号
  • 发送“我爱安卓
  • 即可获取验证码

注册

解锁回答区域

  • 扫码关注公众号
  • 发送“我爱安卓

若你登陆,将永久解锁;
若未登录,仅本机解锁。

解锁回答区域

获取注册验证码

  • 扫码关注公众号
  • 发送“我爱安卓
  • 即可获取验证码

OkOne-基于okhttp的网络性能优化框架

chidehang   2021-01-01 00:21   收藏

OkOne

基于okhttp库的网络性能优化框架

简介

在APP项目中可能会包含多个组件模块,或依赖多个三方库,其中可能都有使用到okhttp框架进行网络请求。不同的组件模块和三方
库间各自创建OkHttpClient实例,或有开发者未通过单例缓存OkHttpClient,而是每次请求每次新建,这样将造成浪费并且导致不能充分利用
okhttp的请求队列和连接池等控制和优化措施。

借助该OkOne库可以无侵入地将分散在不同组件中的OkHttpClient进行收敛,由OkOne进行统一复用和管理。OkOne会比较OkHttpClient.Builder
进行区分复用,即相同配置的OkHttpClient.Builder将自动复用同一个OkHttpClient实例。

除此之外,OkOne还提供了其他扩展的高级功能,更详细的介绍可以查看相关博文:

《OkOne-基于okhttp的网络性能优化框架》

《OkOne-高级功能之OkHttp预建连以及原理剖析》

快速集成

Minimum supported Gradle version is 6.5

Minimum supported OkHttp version is 4.1.0

  • 1.在项目根目录的build.gradle里添加依赖
dependencies {
    classpath 'com.cdh.okone:gradle:0.1.0'
}
  • 2.在app module的build.gradle里应用插件
apply plugin: 'plugin.cdh.okone'
  • 3.在app module的build.gradle的dependencies里添加依赖
implementation 'com.cdh.okone:okone:0.2.0'

至此已完成接入,后续直接打包apk运行即可。

高级功能

关闭开关

是否启用或关闭OkHttpClient统一复用和管理,需要在创建OkHttpClient前设置。

// true启用,false关闭。默认true。
OkOne.useGlobalClient = true;

打印日志

打开或关闭OkOne打印日志。

// true打印,false不打印。默认true。
OkOne.setLogEnable(true);

单独创建不受控的OkHttpClient实例

单独创建一个不经OkOne管理和复用的OkHttpClient。

OkHttpClient client = new OkHttpClient(builder); 

预建连

开发者可以在合适的时机提前建立连接,若连接成功则添加进okhttp连接池。

OkOne.preBuildConnection(okHttpClient, url, new PreConnectCallback() {
    @Override
    public void connectCompleted(String url) {
        Log.d(TAG, "预建连成功: " + url);
    }

    @Override
    public void connectFailed(Throwable t) {
        Log.e(TAG, "预建连失败", t);
    }
});

更新日志

Change Log

项目地址:https://github.com/chidehang/OkOne