切换底层为OkHttp
最后更新于:2022-04-01 23:19:59
# 目录
[TOC]
# 网络层配置
**强烈建议你看此文之前看看[NoHttp的初始化与配置](http://doc.nohttp.net/222342)。**
NoHttp的网络层是通过`NetworkExecutor`接口来配置的,内部提供了一个基于`HttpURLConnection`的接口实现类`URLConnectionNetworkExecutor`,在`NoHttp`项目中用另一个`module`提供了一个基于`OkHttp`的接口实现类`OkHttpNetworkExecutor`,二者选其一即可,关于二者该如何使用选择请看[项目如何引入NoHttp](http://doc.nohttp.net/222341)。
**值得注意的是:**切换了NoHttp的网络底层后,NoHttp的上层代码不需要任何改动,你的应用层代码也不需要任何改动。
默认采用`HttpURLConnection`的实现做底层,既`URLConnectionNetworkExecutor`。
```java
NoHttp.initialize(this, new NoHttp.Config()
...
.setNetworkExecutor(new URLConnectionNetworkExecutor()) // 使用HttpURLConnection做网络层。
);
```
如果要使用OkHttp作为网络层,请在app的gradle中添加依赖:
```groovy
compile 'com.yanzhenjie.nohttp:okhttp:1.1.0'
```
然后在初始化的时候这么做:
```java
NoHttp.initialize(this, new NoHttp.Config()
...
.setNetworkExecutor(new OkHttpNetworkExecutor()) // 使用OkHttp做网络层。
);
```
# 到底该用OKHttp还是URLConnection
好多人咨询到底是使用`HttpURLConnection`还是`OkHttp`,下面做个简单的解释。
`HttpURLConnection`是Android系统自带的api,无需依赖其它任何第三方库。
- HttpURLConnection
* 不用依赖第三方底层框架,相应的apk的体积也不会增大。
* 在5.0以下的系统中`DELETE`请求方法不允许发送`body`,因此会在http协议的实现上做一些妥协。
* 在`Android4.4`以后`HttpURLConnection`的底层使用`OkHttp2.7.5`来实现。
- OkHttp
* `square`开发的第三方框架(非系统集成),相对高效、稳定。
* 写文档的时候OkHttp已经更新到`3.4.1`了。
* 使用OkHttp的好处是第三方框架有bug可以改代码,不像系统集成的api没办法改动。
我个人比较推荐使用OkHttp作为NoHttp的底层,我们公司的所有项目也是用nohttp的,全都是配置okhttp为底层的。
';