Swift4.0 异步Post请求中使用委托以及在委托线程中修改

2017-11-23  本文已影响0人  奶帆

在做APP时经常会用到Post请求网络中的数据,每次使用时要进行大量的配置。所以一般都会将Post请求封装起来,iOS9后一般推荐使用异步的方式进行Post请求,这样的好处是可以避免UI刷新被卡死,用户界面无响应(App Store审核的时候有此情况时会被拒)。

所以在封装异步请求时需要用到委托,以适应不同的调用环境。这里就有简单的例子

我们先定义一个静态方法来发送数据


class func sendMessage(APIURL:String,JsonData:Data,LoginSuccessBlock:@escaping ((Data?,URLResponse?,Error?)->Void))

{

let url=URL.init(string: serverURL+APIURL)

var request=URLRequest(url: url!)

request.httpMethod="POST"//设置请求模式为Post

request.addValue("application/json", forHTTPHeaderField: "Content-Type")//设置Content-Type为Json,有的API会有此要求

request.httpBody=JsonData

let config=URLSessionConfiguration.default

let session=URLSession(configuration: config)//创建会话

let task=session.dataTask(with: request, completionHandler: LoginSuccessBlock)//创建任务,注意completionHandler参数,当请求完成后,会执行Handler部分。同时要注意在子线程中调用UI时会出错,UI只允许从主线程调用,所以这里要用到DispatchQueue.main.async

task.resume()//异步执行任务

}

接下来就是定义回调函数,注意参数要和前面定义Handler部分参数一致


//服务器响应后回调

func EventLoginSuccess(data:Data?,response:URLResponse?,err:Error?)->Void{

//函数体

DispatchQueue.main.async {

//在这里写要调用UI的操作,在调用UI对象之前要加self哦

self.navigationController?.popViewController(animated: true)

}

}

最后调用Post函数部分就简单啦,把对应的值和委托传进去就好啦


WebAPIHelper.sendMessage(APIURL: WebAPIHelper.LoginAPI, JsonData: jsonData, LoginSuccessBlock: EventLoginSuccess(data:response:err:))

上一篇 下一篇

猜你喜欢

热点阅读