4

AFNetworkingでNSProgressを使用しようとしています。これは私が使用しているコードです

//func upload...
//...
let request: NSMutableURLRequest = AFHTTPRequestSerializer().multipartFormRequestWithMethod("POST", URLString: url, parameters: s3parameters, constructingBodyWithBlock: { formData in
      let data: AFMultipartFormData = formData
      data.appendPartWithFileURL(fileURL, name: "file", error: nil)
    }, error: nil)
    request.setValue("application/json", forHTTPHeaderField: "Accept")

    let sessionManager: AFURLSessionManager = AFURLSessionManager(sessionConfiguration: NSURLSessionConfiguration.defaultSessionConfiguration())
    var progress: NSProgress?

    let uploadTask: NSURLSessionUploadTask = sessionManager.uploadTaskWithStreamedRequest(request, progress: &progress, completionHandler: { (response, responseObject, error) in
    //...
    })

    uploadTask.resume()
    progress?.addObserver(self, forKeyPath: "fractionCompleted", options: NSKeyValueObservingOptions.Initial, context: nil)
//...

override func observeValueForKeyPath(keyPath: String, ofObject object: AnyObject, change: [NSObject : AnyObject], context: UnsafeMutablePointer<Void>) {
  let progress: NSProgress = object as NSProgress
  println("progress: \(progress.fractionCompleted)")
}

ファイルは正しくアップロードされますが、そうではありません。進行状況の値が 1 回だけ出力され ("progress: 0.0")、AFURLSessionManager.m 内の EXC_BAD_ACCESS で終了します。

#pragma mark - NSURLSessionTaskDelegate

- (void)URLSession:(__unused NSURLSession *)session
          task:(__unused NSURLSessionTask *)task
didSendBodyData:(__unused int64_t)bytesSent
totalBytesSent:(int64_t)totalBytesSent
totalBytesExpectedToSend:(int64_t)totalBytesExpectedToSend
{
    self.progress.totalUnitCount = totalBytesExpectedToSend; <<< EXC_BAD_ACCESS
    self.progress.completedUnitCount = totalBytesSent;
}

私は何を間違っていますか?「var progress: NSProgress?」を設定する必要がありますか? 違うか、私が見逃している何かがありますか?

4

1 に答える 1

1

ああ、私はそれを修正しました - 進行状況からオブザーバーを削除する必要がありました:

let uploadTask: NSURLSessionUploadTask = sessionManager.uploadTaskWithStreamedRequest(request, progress: &progress, completionHandler: { (response, responseObject, error) in
//...
progress?.removeObserver(self, forKeyPath: "fractionCompleted", context: nil) // added this line
//...
})
于 2015-01-21T09:55:29.447 に答える