Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/swift/16.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ios 如何使用Alamofire 4 SessionManager?_Ios_Swift_Alamofire_Swift3 - Fatal编程技术网

Ios 如何使用Alamofire 4 SessionManager?

Ios 如何使用Alamofire 4 SessionManager?,ios,swift,alamofire,swift3,Ios,Swift,Alamofire,Swift3,我在Swift 2.3中使用了Alamofire 3.4,我需要将代码更新为Swift 3和Alamofire 4。 我用Alamofire的经理在一个url中发布了一篇文章。我阅读了关于SessionManager的文档,我知道请求使用了方法.GET 我使用Manager.Response()从请求中获取回调,现在在SessionManager中更改了 如何使用SessionManager创建POST方法?我如何从请求中得到响应 这是我的原始代码: import UIKit import AE

我在Swift 2.3中使用了Alamofire 3.4,我需要将代码更新为Swift 3和Alamofire 4。 我用Alamofire的经理在一个url中发布了一篇文章。我阅读了关于SessionManager的文档,我知道请求使用了方法.GET

我使用Manager.Response()从请求中获取回调,现在在SessionManager中更改了

如何使用SessionManager创建POST方法?我如何从请求中得到响应

这是我的原始代码:

import UIKit
import AEXML
import Alamofire

class Request: NSObject {

    internal typealias RequestCompletion = (statusCode: Int?, error:NSError?) -> ()
    private var completionBlock: RequestCompletion!

    var serverTrustPolicy: ServerTrustPolicy!
    var serverTrustPolicies: [String: ServerTrustPolicy]!
    var afManager: Manager!

    func buildBdRequest(ip : String, serviceStr : String, completionBlock:RequestCompletion){
       let url = getURL(ip, service: serviceStr)
        configureAlamoFireSSLPinningWithCertificateData()
        makeAlamofireRequest(url)

        self.completionBlock = completionBlock
    }

    func makeAlamofireRequest(url : String){
        self.afManager.request(.POST, url)
            .validate(statusCode: 200..<300)
            .response { request, response, data, error in

                print("data - > \n    \(data.debugDescription) \n")
                print("response - >\n    \(response.debugDescription) \n")
                print("error - > \n    \(error.debugDescription) \n")

                var statusCode = 0

                if response != nil {
                    statusCode = (response?.statusCode)!
                }
                   self.completionBlock(statusCode: statusCode, error: error)
        }

    }


    private func getURL(ip : String, service: String) -> String{
        return ip + service;
    }

    func configureAlamoFireSSLPinningWithCertificateData() {
        self.serverTrustPolicies = [ :
            //            "github.com": self.serverTrustPolicy!
        ]

        self.afManager = Manager(
            configuration: NSURLSessionConfiguration.defaultSessionConfiguration()
        )
    }
}
导入UIKit
导入AEXML
进口阿拉莫菲尔
类请求:NSObject{
内部类型Alias RequestCompletion=(状态代码:Int?,错误:NSError?)->()
私有变量completionBlock:RequestCompletion!
var serverTrustPolicy:serverTrustPolicy!
var serverTrustPolicies:[字符串:ServerTrustPolicy]!
经理:经理!
func buildBdRequest(ip:String,serviceStr:String,completionBlock:RequestCompletion){
让url=getURL(ip,服务:serviceStr)
使用Certificatedata()配置ALAMOFIRESLPINING
MakeAlamoFileRequest(url)
self.completionBlock=completionBlock
}
func makeAlamofireRequest(url:String){
self.afManager.request(.POST,url)
.validate(状态代码:200..String{
返回ip+服务;
}
func使用Certificatedata()配置AlamofResslpinning{
self.serverTrustPolicies=[:
//“github.com”:self.serverTrustPolicy!
]
self.afManager=Manager(
配置:NSURLSessionConfiguration.defaultSessionConfiguration()
)
}
}

我已将您的代码迁移到Swift 3和Alamofire 4,结果如下:

internal typealias RequestCompletion = (Int?, Error?) -> ()?
private var completionBlock: RequestCompletion!
var afManager : SessionManager!


func makeAlamofireRequest(url :String){
    let configuration = URLSessionConfiguration.default

    afManager = Alamofire.SessionManager(configuration: configuration)
    afManager.request(url, method: .post).validate().responseJSON {
                response in
                switch (response.result) {
                case .success:
                    print("data - > \n    \(response.data?.debugDescription) \n")
                    print("response - >\n    \(response.response?.debugDescription) \n")
                    var statusCode = 0
                    if let unwrappedResponse = response.response {
                        let statusCode = unwrappedResponse.statusCode
                    }
                    self.completionBlock(statusCode, nil)

                    break
                case .failure(let error):
                    print("error - > \n    \(error.localizedDescription) \n")
                    let statusCode = response.response?.statusCode
                    self.completionBlock?(statusCode, error)
                    break
                }
            }
}
关于代码的一些注释:

在Alamofire 4.0中,您不需要在代码200..300之间手动验证。
validate()
method自动进行验证

:

自动验证200…299范围内的状态代码,并验证响应的Content Type标头是否与请求的Accept标头匹配(如果提供)

您可以在
responseJSON
方法中使用
response
参数。它包含代码中需要的所有信息

关于
请求
方法

openfunc请求(url:urlconverable,方法:HTTPMethod=.get,参数:参数?=nil,编码:参数编码=URLEncoding.default,头:HTTPHeaders?=nil)->DataRequest

除了URL之外,所有参数最初都为零或有一个默认值。所以向请求中添加参数或头是没有问题的


希望它能帮助你

嗨@yasin,这里有更新吗?@MuruganandhamK没有,还没有。我颠倒了我的代码,继续使用swift 2.3和Alamofire 3.5。请在这里更新。一旦你得到任何更新。同样的问题here@MuruganandhamK您可以查看我的回答您是否必须在每次请求之前重新实例化会话管理器,还是可以共享同一个实例在多个请求之间?@cbbcloud您可以创建一个SessionManager并在多个请求中共享同一实例。@kamwysoc做得很好。您能告诉我为什么使用
.validate()。
吗?@Jack请阅读文档(旧)SessionManager>(新)会话