在做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:))