iOS & 网络请求Alamofire及数据转换ObjectMapper

Alamofire & AlamofireObjectMapper

对于掌握一门新技术而言,请求接口数据Alamofire及数据转换ObjectMapper是必不可少的。

而技术选型只是大致调研了下,然后集成到项目中,多了解多对比,后面再优化或者替换。

因为用了Alamofire ,所以数据转换ORM这块选用了更适用的 AlamofireObjectMapper

作为一个小白,仿佛一切又回到了起点,用了太久的GraphQL自动生成POJO,从不用担心ORM这块的我,终于又要手敲转换类了。

小白总要将就,先使用AlamofireObjectMapper手动生成POJO,后面有合适的再换

1.修改Podfile文件,安装相应库

Pod 增加配置

执行安装命令

arch -x86_64 Pod install
安装成功

2.生成转换类

// 接口返回数据结构
{
     "result": {
         "songs": [
             {
                 "id": 347230,
                 "name": "海阔天空",
                 "artists": [
                     {
                         "id": 11127,
                         "name": "Beyond",
                         "picUrl": null,
                         "alias": [],
                         "albumSize": 0,
                         "picId": 0,
                         "img1v1Url": "http://p1.music.126.net/6y-UleORITEDbvrOLV0Q8A==/5639395138885805.jpg",
                         "img1v1": 0,
                         "trans": null
                     }
                 ],
                 "duration": 326000,
                 "copyrightId": 7002,
                 "status": 0,
                 "alias": [],
                 "rtype": 0,
                 "ftype": 0,
                 "transNames": [
                     "Boundless Oceans, Vast Skies"
                 ],
                 "mvid": 376199,
                 "fee": 1,
                 "rUrl": null,
                 "mark": 8192
             }
         ],
         "hasMore": true,
         "songCount": 524
     },
     "code": 200
 }

字段太多了,只选择几个典型的进行转换

//
//  SongsResponse.swift
//  AlamofireDemo
//
//  Created by Jake on 2021/7/20.
//

import ObjectMapper

/**
  请求转换基类 ( 竟然需要手写,后面要找自动生成的插件 )
  map 可以跨越无用的中间类,例如 :name <- map["result.songs.1.name"]
 */

class ResultBase: Mappable {
    
    var songs : [Songs]?
    var code : Int?
//    var name : String?
    
    required init?(map: Map) {
    
    }
    
    func mapping(map: Map) {
        songs <- map["result.songs"]
        code <- map["code"]
//        name <- map["result.songs.1.name"]
    }
    
}

class Songs:  ResultBase{

    var id :Int?
    var name : String?
    var imageUrl : String?

    required init?(map: Map) {
        super.init(map: map)

    }

    override func mapping(map: Map) {
        super.mapping(map: map)
        id <- map["id"]
        name <- map["name"]
        // 默认取第一个 artists 的 img1v1Url
        imageUrl <- map["artists.0.img1v1Url"]
    }

}

注意:类的继承与super的调用;还有子类名要与接口返回一致。
Map的匹配规则:可跳跃用不到的属性,但是一定要注意与字段名一致。

// 跳跃举例如下
songs <- map["result.songs"]
imageUrl <- map["artists.0.img1v1Url"]

3.网络请求

Alamofire 封装了很多返回值的格式,此处用 responseObject ,原因上面说过了

    override func viewDidLoad() {
        super.viewDidLoad()
        // 简陋的网络请求,后面要封装
        _ = Alamofire.request("http://192.168.10.3:3000/search?keywords=%E6%B5%B7%E9%98%94%E5%A4%A9%E7%A9%BA")
            .responseObject(completionHandler: { (response: DataResponse<ResultBase>) in
                switch response.result {
                case let .success(data):
                    if data.songs != nil {
                     self.queryData = data.songs!
                     self.creatTableView()
                    }

                break
                case let .failure(data):
                    print(data.localizedDescription)
                break
                }
            })
        
    }

4.页面展示

Table View 展示列表数据

5.附上简陋的VC代码,待整理。

//
//  ViewController.swift
//  AlamofireDemo
//
//  Created by Jake on 2021/7/19.
//

import UIKit
import Alamofire
import AlamofireObjectMapper

class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
    
    var tableView: UITableView!
    var queryData:[Songs] = []
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        self.queryData.count
    }
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell: UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "cell")!
        let id = self.queryData[indexPath.row].id ?? 0
        let name = self.queryData[indexPath.row].name ?? ""
        cell.textLabel?.text = name + "> > id \(id)"
        return cell
    }
    
    func numberOfSections(in tableView: UITableView) -> Int {
        self.queryData.count
    }
    
    /// 创建表格
     func creatTableView() {
         self.tableView = ({
             let tableView = UITableView(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height), style: .plain)
             tableView.delegate = self
             tableView.dataSource = self
             tableView.separatorStyle = .none
             tableView.register(UITableViewCell.classForCoder(), forCellReuseIdentifier: "cell")
             self.view.addSubview(tableView)
             return tableView
         })()
     }

    override func viewDidLoad() {
        super.viewDidLoad()
        // 简陋的网络请求,后面要封装
        _ = Alamofire.request("http://192.168.10.3:3000/search?keywords=%E6%B5%B7%E9%98%94%E5%A4%A9%E7%A9%BA")
            .responseObject(completionHandler: { (response: DataResponse<ResultBase>) in
                switch response.result {
                case let .success(data):
                    if data.songs != nil {
                     self.queryData = data.songs!
                     self.creatTableView()
                    }
                break
                case let .failure(data):
                    print(data.localizedDescription)
                break
                }
            })
    }
}

うずまき ナルト
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容

  • 在实际项目开发过程中,很多时候移动终端设备都要与服务器进行数据交互。两者之间的数据格式通常为 JSON 和 XML...
    Anenn阅读 11,353评论 6 22
  • 用到的组件 1、通过CocoaPods安装 2、第三方类库安装 3、第三方服务 友盟社会化分享组件 友盟用户反馈 ...
    SunnyLeong阅读 14,609评论 1 180
  • 表情是什么,我认为表情就是表现出来的情绪。表情可以传达很多信息。高兴了当然就笑了,难过就哭了。两者是相互影响密不可...
    Persistenc_6aea阅读 124,712评论 2 7
  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 6,042评论 0 4