[快速学会Swift第三方库]AlamofireObjectMapper

前端之家收集整理的这篇文章主要介绍了[快速学会Swift第三方库]AlamofireObjectMapper前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

[快速学会Swift第三方库]AlamofireObjectMapper篇

通常网络请求返回的是JSON数据,使用ObjectMapper可以让JSON数据直接转化为对象,而使用Alamofire进行网络请求时,使用AlamofireObjectMapper可以直接返回对象,更加简洁。
Alamofire的使用:[快速学会Swift第三方库] Alamofire篇
ObjectMapper在非Alamofire请求下的使用:GitHub-ObjectMapper主页

目录

编码之前

导入AlamofireObjectMapper

推荐使用CocoaPods进行导入,CocoaPods是一个负责管理iOS项目中第三方开源库的工具,安装CocoaPods之后使用命令行就能轻松地对所有第三方开源库进行安装和更新,而不需要每次上GitHub去下载。
CocoaPods的安装过程传送门:iOS 9 导入类库全面详尽过程(Ruby安装->CocoaPods安装->导入类库)
手动下载:GitHub-AlamofireObjectMapper 主页

装好CocoaPods后,修改Podfile文件内容为如下:

source 'https://github.com/CocoaPods/Specs.git'
platform :ios,'9.0'
use_frameworks!

target 'Web' do
pod 'AlamofireObjectMapper','~> 3.0'
end
xcodeproj 'Desktop/Web/Web.xcodeproj'

target后面为工程名,最后一行为工程路径(这里的Web是我的工程名)

再执行命令:

$ pod install

注意:会自动导入ObjectMapper

其他操作

另外还需要在Target->工程名->Build Settings->Search Paths->User Header Search Paths处添加AlamofireObjectMapper所在的目录:

最后在你需要用到AlamofireObjectMapper的类中加上

import AlamofireObjectMapper

创建 Mappable 对象

这里采用的Alamofire的测试接口 https://httpbin.org/get

在浏览器中打开可以看到JSON格式的数据:

{
  "args": {},"headers": { "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8","Accept-Encoding": "gzip,deflate,br","Accept-Language": "zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3","Cache-Control": "max-age=0","Host": "httpbin.org","User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:46.0) Gecko/20100101 Firefox/46.0" },"origin": "202.115.52.218","url": "https://httpbin.org/get" }

根据该JSON的数据格式创建以下两个Mapper类分别对应整个字典和key值为“header”的字典。将JSON中的数据与对象中的数据一一建立转化关系。

import Foundation
import ObjectMapper

class ResponseHeader: Mappable {

    var accept : String?
    var acceptEncoding : String?
    var acceptLanguage : String?
    var cacheControl : String?
    var host : String?
    var userAgent : String?

    required init?(_ map: Map) {

    }

    //映射heades字典中的所有键值
    func mapping(map: Map) {
        accept <- map["Accept"] acceptEncoding <- map["Accept-Encoding"] acceptLanguage <- map["Accept-Language"] cacheControl <- map["Cache-Control"] host <- map["Host"] userAgent <- map["User-Agent"] } }
import Foundation
import ObjectMapper

class MyResponse: Mappable {
    var args : NSDictionary?
    var headers : ResponseHeader?
    var origin : String?
    var url : String?

    required init?(_ map: Map) {

    }

    //映射字典中的所有键值
    func mapping(map: Map) {
        args <- map["args"] headers <- map["headers"] origin <- map["origin"] url <- map["url"] } }

用Alamofire获取对象

func webRequst()  {
        let url = "https://httpbin.org/get"
        //注意返回的类型为<Mappable对象,NSError>
        Alamofire.request(.GET,url).responSEObject { (response: Response<MyResponse,NSError>) in
            let myResponse = response.result.value
            print(myResponse?.url)
            if let header = myResponse?.headers{
                print(header.userAgent)
            }
        }
    }

返回的Mappable对象可以直接使用,运行结果:

Optional("https://httpbin.org/get")
Optional("Web/com.applelab.Web (1; OS Version 9.3 (Build 13E230))")

深入学习

如果你想更多地了解AlamofireObjectMapper,可以前往GitHub-ObjectMapper主页

猜你在找的Swift相关文章