Swift5.0的网络请求与数据解析

封装了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解析成StringString解析成Int

2.0 更新到swift4,重新整理代码

1.2 新增moya的demo

1.1 新增链式请求的封装

  • 链式请求可以只组合需要的函数,本身默认为常用方式,简化常用的链式调用
  • 对于非默认值的请求可以自定义进行设置
  • 方便添加自定义行为,利于扩展

1.0 类OC中的AFN封装

  • 利于OC转swift的同学学习
  • 其中对返回值做了JSON和String两种解析,String是为了方便实用HandyJSON,不使用HandyJSON可以自行删除部分代码

你可能感兴趣的:(Swift5.0的网络请求与数据解析)