封装了moya,链式,类AFN式请求
SwiftHttpRequest Github地址
在线转model工具
更新说明:
version 2.1:
Codable
增加跨类型解析方式:感谢hhfa008大神提供的方式
后台最常用的类型,也是最容易让我们出错的就是Int和String类型的不确定,
这里提供了后台同一个字段返回类型Int和String不确定时的解析方式,
可自行增加Bool类型等。
自定义解析类型如下,示例见demo
///跨类型解析方式
// 一个含有int,string的类,可用于解析后台返回类型不确定的字段。即:把int\string解析成TStrInt且解析后TStrInt的int和string都有值
//----- 使用时如果报未初始化的错误,而且找不到原因时,可以尝试先修复model以外的错误,也许这个错误就会消失。。。。 这是编译器提示错误的原因
struct TStrInt: Codable {
var int:Int {
didSet {
let stringValue = String(int)
if stringValue != string {
string = stringValue
}
}
}
var string:String {
didSet {
if let intValue = Int(string), intValue != int {
int = intValue
}
}
}
init(from decoder: Decoder) throws {
let singleValueContainer = try decoder.singleValueContainer()
if let stringValue = try? singleValueContainer.decode(String.self)
{
string = stringValue
int = Int(stringValue) ?? 0
} else if let intValue = try? singleValueContainer.decode(Int.self)
{
int = intValue
string = String(intValue);
} else {
int = 0
string = ""
}
}
}
Demo说明
Demo主要介绍Swift的网络部分,代码已更新到swift4
一. 网络部分
请求均采用 Alamofire
请求封装方式分为:
- 1.Moya(一个star很多的
Alamofire
的上层封装,为本demo推荐方式。我在使用过程中发现moya是极其优美的网络请求方式) - 2.链式请求(如果你刚刚从OC转到swift,可能还不适应moya的方式,那么也可以用这种请求方式)
- 3.仿AFN式请求(这应该是OC中常见的封装方式)
二. Progress及信息处理
加载动画及弹出框采用 MBProgressHUD
三. 数据解析
在swift4之前,我一直用的是HandyJSON
(下面有介绍)。在swift4之后我把model的解析转到到官方的Codable。
四. 缓存
缓存部分没有接入数据库,而是直接用了write to file
,并将缓存封装到网络请求方法中
本demo内容可直接用于项目开发
三方库介绍
Alamofire:Swift中著名的网络请求库
Moya:著名的Alamofire封装,让网络请求看起来更加的优美,更有利于阅读与迭代
MBProgressHUD: 进度条,弹出框,OC写的库
Kingfisher: 加载网络图片,类似SDWebImage
已弃用
HandyJSON 是阿里巴巴开源的model的映射库。使用方式类似OC中的MJExtention
ObjectMapper:json解析库,需要手动写映射关系
具体可以看在Swift语言中处理JSON - 转换JSON和Model
接口说明
本demo使用接口为多米音乐接口
http://v5.pc.duomi.com/search-ajaxsearch-searchall?kw=关键字&pi=页码&pz=每页音乐数
请求数据参数:kw=像我这样的人&pi=1&pz=1
返回实例:
{
"album_offset": 0,
"albums": [
{
"artists": [
{
"id": 61799986,
"name": "Mc名决",
"portrait": null,
"valid": false
}
],
"available": true,
"company": "",
"cover": "http://pic.cdn.duomi.com/imageproxy2/dimgm/scaleImage?url=http://img.kxting.cn//p1/08/16/72494779.jpg&w=150&h=150&s=100&c=0&o=0&m=",
"id": 2742662,
"name": "像我这样的人",
"num_tracks": 4,
"release_date": "2017-08-22",
"type": "EP/单曲"
}
],
"artist_offset": 0,
"artists": null,
"dm_error": 0,
"error_msg": "操作成功",
"recommend": 0,
"total_albums": 1,
"total_artists": 0,
"total_tracks": 6,
"track_offset": 0,
"tracks": [
{
"album": {
"cover": "/p1/12/17/72493295.jpg",
"id": 2741390,
"name": "裙娣"
},
"artists": [
{
"id": 61792091,
"name": "DJ马哥",
"num_albums": 35,
"num_tracks": 233,
"portrait": "",
"valid": false
}
],
"availability": "1110",
"dlyric": "",
"id": 28136457,
"medias": [
{
"bitrate": 320,
"p2purl": "1A4DF5035CE09DB8DF0500000060CFABAC000000A9.mp3"
}
],
"mv": 0,
"slyric": "",
"title": "像我这样的人",
"isdown": "1",
"isplay": "1"
}
]
}
作者语:
希望能达到抛砖引玉的效果
也给新学习swift的朋友一个简单的网络处理的方式
大家互相帮助,互相学习
如果对你有帮助还请给个Star,谢谢🙏
版本:
2.1 Codable
跨类型解析:Int
解析成String
, String
解析成Int
2.0 更新到swift4,重新整理代码
1.2 新增moya
的demo
1.1 新增链式请求的封装
- 链式请求可以只组合需要的函数,本身默认为常用方式,简化常用的链式调用
- 对于非默认值的请求可以自定义进行设置
- 方便添加自定义行为,利于扩展
1.0 类OC中的AFN封装
- 利于OC转swift的同学学习
- 其中对返回值做了JSON和String两种解析,String是为了方便实用HandyJSON,不使用HandyJSON可以自行删除部分代码