Swift网络封装库Moya中文手册之Providers
Providers
使用Moya,你可以通过一个 MoyaProvider
的实例发送所有网络请求,通过枚举来指定你要访问的具体API。在配置你的 Endpoint 之后,你差不多就做好了基础配置:
let provider = MoyaProvider<MyService>()
简单配置后,你就可以使用:
provider.request(.Zen) { result in
// `result` is either .Success(response) or .Failure(error)
}
就是这样!request()
方法返回一个 Cancellable
,这只有一个函数,用于取消请求。 更多关于 Result
的信息请查阅 Examples。
记住,target和provider放在什么地方,完全由你自己决定。可以参考 Artsy's implementation 作为示例。
但不要忘了provider要作为属性持有,如果中途被释放的话,会出现"cancelled"` 的错误提示。
高级用法
为了解释清楚 MoyaProvider
的所有结构参数,我们将在下面一个个讲解。
endpointClosure:
MoyaProvider
初始化的第一个参数(可选)是一个endpoints闭包,它可以将你的target转换成具体的Endpoint
实例。让我们看看应该怎么写。
let endpointClosure = { (target: MyTarget) -> Endpoint<MyTarget> in
let url = target.baseURL.URLByAppendingPathComponent(target.path).absoluteString
return Endpoint(URL: url, sampleResponseClosure: {.NetworkResponse(200, target.sampleData)}, method: target.method, parameters: target.parameters)
}
let provider = MoyaProvider(endpointClosure: endpointClosure)
注:这样初始化 MoyaProvider
的时候,不需要再说明target的具体类型,Swift会根据endpointClosure
推断。
endpointClosure
就是这么简单。MoyaProvider.DefaultEndpointMapping
有默认实现。
如果需要自定义,请查看 Endpoints 文档。
requestClosure:
另一个可选的初始化参数是 requestClosure
,可以将 Endpoint
转换为 NSURLRequest
。同样,查看 Endpoints 文档可以获得更多信息。
stubClosure:
下一个选择是提供一个 stubClosure
。它返回一个.Never
(默认),或者.Immediate
, 或者.Delayed(seconds)
, 你可以延迟这个stub模拟请求(具体n秒)。例如,.Delayed(0.2)
会把每个stub模拟请求延迟0.2s。 这在单元测试中可以很好的模拟网络延迟。
这样的好处是当你需要模拟不同于其他的特殊请求时,可以编写自己的闭包。
let provider = MoyaProvider<MyTarget>(stubClosure: { target: MyTarget -> Moya.StubBehavior in
switch target {
/* Return something different based on the target. */
}
})
但大多数时候你想对所有targets做同样的模拟测试,这里有三个 MoyaProvider
的函数可以直接调用用。
MoyaProvider.NeverStub
MoyaProvider.ImmediatelyStub
MoyaProvider.DelayedStub(seconds)
所以,如果你就是要做同样的模拟测试,可以像下面这样写:
let provider = MoyaProvider<MyTarget>(stubClosure: { (_: MyTarget) -> Moya.StubBehavior in return .Immediate })
let provider = MoyaProvider<MyTarget>(stubClosure: MoyaProvider.ImmediatelyStub)
manager:
接下来是 manager
参数。默认的,你可以通过基本设置获得一个Alamofire.Manager
。
public final class func DefaultAlamofireManager() -> Manager {
let configuration = NSURLSessionConfiguration.defaultSessionConfiguration()
configuration.HTTPAdditionalHeaders = Alamofire.Manager.defaultHTTPHeaders
let manager = Alamofire.Manager(configuration: configuration)
manager.startRequestsImmediately = false
return manager
}
有一点需要特别注意:在AF中,构造一个 Alamofire.Request
会默认立即发起请求,包括在单元测试模拟请求的时候。因此在Moya中, startRequestsImmediately
默认设为 false
。
如果你想自定义自己的manager,例如,加上SSL pinning,所有请求都将会通过自定义的manager发送。代码如下:
let policies: [String: ServerTrustPolicy] = [
"example.com": .PinPublicKeys(
publicKeys: ServerTrustPolicy.publicKeysInBundle(),
validateCertificateChain: true,
validateHost: true
)
]
let manager = Manager(
configuration: NSURLSessionConfiguration.defaultSessionConfiguration(),
serverTrustPolicyManager: ServerTrustPolicyManager(policies: policies)
)
let provider = MoyaProvider<MyTarget>(manager: manager)
plugins:
最后,你可能需要一个 plugins
数组。它们在发起请求之前和收到返回值之后回调。这儿已经有一小部分plugins:一个是network activity (NetworkActivityPlugin
), 一个打印输出所有network activity (NetworkLoggerPlugin
),另一个是 HTTP Authentication.
例如,你只需要将 [NetworkLoggerPlugin()]
作为参数传递给 Endpoint
的plugins
,就可以允许log。注意:plugin也可以配置,比如 NetworkActivityPlugin
需要一个networkActivityClosure
参数。配置代码如下:
public final class NetworkActivityPlugin: PluginType {
public typealias NetworkActivityClosure = (change: NetworkActivityChangeType) -> ()
let networkActivityClosure: NetworkActivityClosure
public init(networkActivityClosure: NetworkActivityClosure) {
self.networkActivityClosure = networkActivityClosure
}
// MARK: Plugin
/// Called by the provider as soon as the request is about to start
public func willSendRequest(request: RequestType, target: TargetType) {
networkActivityClosure(change: .Began)
}
/// Called by the provider as soon as a response arrives
public func didReceiveResponse(data: NSData?, statusCode: Int?, response: NSURLResponse?, error: ErrorType?, target: TargetType) {
networkActivityClosure(change: .Ended)
}
}
networkActivityClosure
是一个闭包,你可以在请求开始或结束时进行一些操作。和network activitiy indicator 一起很好用。
注意这个闭包的参数 (change: NetworkActivityChangeType) -> ()
,你只能在request .Began
或者 .Ended
的时候使用,无法提供请求的其他任何细节。
转载请注明出处http://www.cnblogs.com/liuliuliu/p/5627650.html,并注明转载。
原文链接
翻译: bibibi_liuliu
联系方式: 395985239@qq.com
Swift网络封装库Moya中文手册之Providers的更多相关文章
- Swift网络封装库Moya中文手册之Authentication
Authentication 安全验证可能有点复杂,一些网络请求需要认证,这里我们讨论两种常见的. Basic HTTP Auth HTTP auth是HTTP协议自带的用户名/密码验证.如果你使用的 ...
- Swift网络封装库Moya中文手册之Endpoints
Endpoints Endpoint是一种半私有的数据结构,Moya用来解释网络请求的根本构成.一个endpoint储存了以下数据: The URL. The HTTP method (GET,POS ...
- Swift网络封装库Moya中文手册之Plugins
Plugins Moya plugins用于反映请求的发起或接收.Plugins定义为 PluginType 属性,可以在请求准备发起和接收到返回数据时回调. Built in plugins Moy ...
- Swift网络封装库Moya中文手册之RxSwift
RxSwift Maya提供了一个可选的MoyaProvider 子类 - RxMoyaProvider.在网络请求完成时,我们不再使用 request() 函数的回调闭包,而是使用 Observab ...
- Swift网络封装库Moya中文手册之Targets
Targets 使用Moya,我们首先需要定义一个target - 这通常是继承 TargetType 协议的 枚举 变量.接下来,你的app只需要处理这些targets,也就是一些你希望调用API完 ...
- EasyX库简单中文手册
EasyX库简单中文手册 作者: 时间: 2021/2/2 第一个例程 #include <graphics.h> // 图像相关库 #include <conio.h> // ...
- Swift:网络库Alamofire
一,Alamofire的说明与配置 1,什么是Alamofire (1)Alamofire 的前身是 AFNetworking.AFNetworking 是 iOS 和 OS X 上很受欢迎的第三方H ...
- swift中第三方网络请求库Alamofire的安装与使用
swift中第三方网络请求库Alamofire的安装与使用 Alamofire是swift中一个比较流行的网络请求库:https://github.com/Alamofire/Alamofire.下面 ...
- Swift中文手册 -- The Basics
原文:Swift中文手册 -- The Basics 基础部分 Swift 是 iOS 和 OS X 应用开发的一门新语言.然而,如果你有 C 或者 Objective-C 开发经验的话,你会发现 S ...
随机推荐
- Centos用yum方式安装nodejs和npm
要通过 yum 来安装 nodejs 和 npm 需要先给 yum 添加 epel 源 ##添加 epel 源 rpm -ivh http://download.fedoraproject.org/p ...
- HDU 5876 Sparse Graph(补图中求最短路)
http://acm.hdu.edu.cn/showproblem.php?pid=5876 题意: 在补图中求s到其余各个点的最短路. 思路:因为这道题目每条边的距离都是1,所以可以直接用bfs来做 ...
- UVa 116 单向TSP(多段图最短路)
https://cn.vjudge.net/problem/UVA-116 题意:给出m行n列的整数矩阵,从第一列任何一个位置出发每次往右,右上或右下走一格,最终到达最后一列,要求经过的整数之和最小. ...
- BM25 调参调研
1. 搜索 ES 计算文本相似度用的 BM25,参数默认,不适合电商场景,可调整 BM25 参数使其适用于电商短文本场景 2. k1.b.tf.L.tfScore 的关系如下图红框内所示(注:这里的 ...
- bootstrap3显示5列的方法
bootstrap是个12栅格的系统,显示5列比较麻烦,今天用到到网上找了找方法,尝试成功,记录一下,以后好用. 需要自己再添加几个 css class样式: <style> .col-l ...
- matplotlib-绘制精美的图表
matplotlib库链接:http://matplotlib.org/gallery.html matplotlib绘制精美图标链接:http://old.sebug.net/paper/books ...
- Python mysql-数据库基础知识
2017-09-05 19:10:55 一.数据库定义 从本质上讲,数据库就是信息的集合,它可以存在很长时间,往往是很多年.一般来讲,"数据库"这个词指的是有数据库管理系统管理的数 ...
- wpf窗口阴影
https://www.cnblogs.com/yiyan127/p/6362509.html
- Sqlite3,维基百科中的练习:
https://en.wikibooks.org/wiki/SQL_Exercises/The_computer_store 两个相连的表格 Manufactures: code, name prod ...
- Educational Codeforces Round 57题解
A.Find Divisible 沙比题 显然l和2*l可以直接满足条件. 代码 #include<iostream> #include<cctype> #include< ...