为什么NSURLSession.dataTaskWithURL()不会调用我的完成处理程序?

时间:2016-09-10 00:48:17

标签: ios json swift nsurlsession

我试图从网络服务器加载JSON文件。以下是我如何启动请求:

let url:NSURL? = NSURL(string: lookupUrlFragment + query)

// Check if an actual url object was created
if let actualUrl = url {

    // Create a default NSURLSessionConfiguration
    let sessionConfig:NSURLSessionConfiguration = NSURLSessionConfiguration.defaultSessionConfiguration()

    // Create a default session
    let session:NSURLSession = NSURLSession(configuration: sessionConfig)

    session.dataTaskWithURL(actualUrl, completionHandler: {
        (data:NSData?, response:NSURLResponse?, error:NSError?) in
        NSLog("Got data = \(data)")
        NSLog("Got response = \(response)")
        NSLog("Got error = \(error)")
        self.searchResults = data
        self.delegate?.searchResultsAreReady()
   })
}

我已经使用调试器逐步完成了此代码。当它调用dataTaskWithURL()时,实际Url的值是正确的。如果我从网络浏览器点击它,我会得到JSON文件。但完成处理程序永远不会被调用。它永远不会在我在完成处理程序中设置的断点处停止,并且调试器日志中不会显示任何输出。

我已经在一个单独的函数中使用完成处理程序而不是闭包来尝试这个,但行为是相同的。

有谁能告诉我为什么我的完成处理程序没有被调用?

2 个答案:

答案 0 :(得分:5)

您忘了拨打resume()

let session:NSURLSession = NSURLSession(configuration: sessionConfig)

let task = session.dataTaskWithURL(actualUrl, completionHandler: {
    (data:NSData?, response:NSURLResponse?, error:NSError?) in
    NSLog("Got data = \(data)")
    NSLog("Got response = \(response)")
    NSLog("Got error = \(error)")
    self.searchResults = data
    self.delegate?.searchResultsAreReady()
})
task.resume() // you miss this

答案 1 :(得分:0)

你永远不会开始这项任务。试试这个:

let url:NSURL? = NSURL(string: lookupUrlFragment + query)

// Check if an actual url object was created
if let actualUrl = url {

    // Create a default NSURLSessionConfiguration
    let sessionConfig:NSURLSessionConfiguration = NSURLSessionConfiguration.defaultSessionConfiguration()

    // Create a default session
    let session:NSURLSession = NSURLSession(configuration: sessionConfig)

    let task = session.dataTaskWithURL(actualUrl, completionHandler: {
        (data:NSData?, response:NSURLResponse?, error:NSError?) in
        NSLog("Got data = \(data)")
        NSLog("Got response = \(response)")
        NSLog("Got error = \(error)")
        self.searchResults = data
        self.delegate?.searchResultsAreReady()
     })

     task.resume()
}