从零开始搭建swift开发框架(一)网络库篇
最近写了一个基于swift的ios开发框架 swiftArch
swift智能开发框架 用最少的代码完成页面 智能分页(策略设计模式) cell和section解耦 业务拆分 mock管理
准备写一个系列的文章来介绍我是如何从零开始搭建
一个好用的网络库,除了有良好的性能,以及丰富的功能之外还有一件最重要的事情就是,方便调用
基本功能至少涵盖了上传,下载,参数封装,方法封装,网络日志,缓存,还有最重要的功能,自动解析json模型
alamofire是最常用和最著名的swift开发框架,拥有丰富的功能和良好的口碑,我的网络库就是基于alamofire的二次封装.
先看看我的网络库包含哪些内容 有针对alamofire参数封装的httpclient 日志管理器NetLogger,缓存管理,和json解析工具
先看看我是如何暴露接口的
调用1:缓存
调用2:不缓存
由于现在前后端分离的趋势,越来越多的服务端接口采取restful开发模式
所以请求参数不仅仅是 放在放在url上以?pageNum=0&pageSize=20的形式了
所以还需要针对放在path中的参数进行处理 user/manondidi/school
而且一套系统返回的一般都是一个固定的json模型通常包含有
statusCode(状态码) msg(错误信息) data(真正想返回的内容) 三个节点
所以我的网络库至少需要2个功能:1.path参数封装 2.自动解析model
1.path参数:
httpClient.request(url:"user/{userId}", method: .post, pathParams: ["userId":userId ], params: ["password":password])
调用的方式很简单 在传入url的时候把path参数以{param}的方式放在字符串中,在后面的字典中把key和value写好
2.json自动解析
这里我使用阿里巴巴的 HandyJson
由于我的request方法的返回值是alamofire的DataRequest对象
所以,我对DataRequest进行了扩展 extends
在方法中需要<传入泛型> 就是你期望转换成的model类型
所以再也不需要自己去解析模型了,只要关注两个回调 success failure就行了
3缓存,我使用 sqllite 在每次alamofire请求成功的时候,生成一个key,将json字符串保存下来
而我暴露的接口是,每次都做存储动作,是否读取由参数决定,并在success中提供本次回调是否是缓存
4.网络日志
简简单单
目前介绍的是网络框架,后面会陆续介绍剩下的内容,具体整套框架