-
Notifications
You must be signed in to change notification settings - Fork 6
Home
oksimple是一个对okhttp进行二次封装的网络请求库,简单易用,扩展性强,基于okhttp5.X版本和kotlin。需要注意的是,项目中的一些类其实是属于示范类的代码,本不应该提交上来,比如DataCallBack和RequestUntilSuccess,但是一开始push的时候提交了上来,后面也就一直没删除,如果看到这类代码,无视就好了。如果需要理解源码的话,更多的关注那几个基类就好了,比如ResultCallBack,因为在实际项目里,更多的还是从基类开始重写,这些示范代码是没法直接拿来用的。
单独使用okhttp,每个请求你都需要编写request,处理callback,编码量太大。而使用retrofit,你又需要写太多的接口。而相对于目前现有的其他一些网络请求框架,oksimple对开发者更加友好。因为很多网络请求框架内部有很多复杂的逻辑,但这些未必适合每个人。oksimple选择尽可能的暴露okhttp原有接口与参数。扩展性更强且便于使用。
我并不喜欢重复造轮子,大多数时候,我选择使用或者修改别人已经写好的东西。但在用了很多网络请求框架之后,我发现没有一个满足我的所有需求,它们大都需要我去阅读并修改源码。因为它们很多都存在一些问题,最典型的便是“过度封装”和“复杂化”。下面我会分别谈谈这两个问题:
框架应该是简单易用的,很多东西应该交给使用者去自己处理。但很多框架喜欢对诸如500,404等返回码进行处理,或者对okhttp的response封装好几层,导致我想看一下原始数据都十分费力。这种框架或许适合公司内部使用,但开源给很多人使用就会发现无法满足所有人的需求。同时,这样的过度封装甚至会让公司内部员工也觉得非常不方便。
很多网络请求框架喜欢引入rxjava,数据库,lifecycle,livedata,协程等等各种看似可以帮助你节约开发成本的事情。然而现实情况往往是让简单的事情变复杂。
我个人认为开源的网络请求框架应当尽可能简单,简单到只包含okhttp这一个依赖足矣。至于是否需要rxjava,数据库,lifecycle,livedata,协程等这些东西,应当交给使用者自己去决定。网络框架应该要做的就是提供同步和异步请求。
你以为帮助别人节省了时间,实际上别人阅读和理解你的框架的时间却变的更多。
基于以上两点,我决定自己写一个适合自己风格的网络请求框架。所以有了oksimple,oksimple相比其他很多网络框架,它的特点就像它的名字,足够简单,扩展性很强,只专注于进行网络请求,而没有其他花里胡哨的东西。推荐给以前的朋友同事之后,得到了他们的一致好评,未来还会继续迭代更新。