天天看点

Swift 3.0封装 URLSession 的GET/SET方法代替 Alamofire

升级到 Swift3.0 之后,新版本的 Alamofire 只支持 iOS 9.0 以上的系统,如果要适配 iOS 8,需要自己封装 URLSession,下面是笔者的方案:

这里使用的是 Swift 自己的原生类型 URLSession,而不是NSURLSession。

Alamofire 4.0 中的request方法的参数列表如下:

method参数的类型是HTTPMethod,这个是系统类型,可以从外部传值,默认值是get。在request方法的方法体中,调用SessionManager.default.request方法,接受了全部的外部参数,并返回一个组装好的 DataRequest对象:

SessionManager.default.request方法的实现如下:

这个方法主要完成的工作是加工request:使用url、method和headers三个参数创建一个URLRequest对象,然后把参数parameters中保存的HTTP请求携带的参数按照encoding所指定的编码方式进行编码得到最终的URLRequest对象,只有这两步都顺利完成了编码才算成功。成功后调用另一个重载的request方法,这个方法接受request字面量,可以直接传入生成的URLRequest对象。失败的情况下调用的是另一个重载的request方法,接受一个Error类型,实际上所有失败的情况下都会调用这个request方法。

所有重载版本的request方法最后都会返回一个 DataRequest类型,这个DataRequest是Alamofire封装的request对象,绕的有点晕。如果你准备自己封装,需要创建一个URLRequest对象代替DataRequest,这里我用了SwiftyJSON库,用来序列化网络返回的结果:

Alamofire的调用是函数式的,使用Alamofire请求返回一个son格式的数据的时候使用的是 responseJSON 方法,原来的格式大致如下:

responseJSON方法的回调是基于result的状态的,但是原生的URLResponse对象没有这个状态,所以你需要自己去判断成功与失败的状态:

此时如果删掉

会发现有几处报错的地方,这是因为我们仍旧在使用Alamofire中的代码,首先HTTPMethod这个枚举类型是定义在Alamofire中的,因为原生API中指定HTTP方法使用的是字符串格式,编译器不会帮你检查错误,你可以把HTTPMethod的定义拷贝出来:

然后我们创建的URLRequest使用的实际上是Alamofire扩展的URLRequest,你需要自己动手写一个扩展,实现一个相同的构造器:

下一个问题是,Alamofire封装了一套把参数写进HTTP请求的编码方法,也就是你调用的:

这个方法中非常多依赖的方法,罗列如下:

这一系列方法抛出的错误也是Alamofire自己定义的,拷贝出来:

现在报错的代码部分修改为:

继续阅读