NSURLErrorDomain Code = -999使用AFNetworking示例代码

时间:2015-01-26 15:33:16

标签: php ios afnetworking afnetworking-2

我正在使用AFNetworking中的示例来使多部分表单上传工作。

我有一个php应用程序,它在一个正在运行的网址上有一个多部分表单:

digital@nefarious-3 [03:26:21] [~]
-> % curl --form "upload=@Snow.jpg" http://example.dev/api/v1/sendFile
["Successful"]

以上是我正在尝试使用AFNetworking请求的相同端点。只有在api端成功处理文件时才会生成该消息。

以下是服务器上ls -lash的输出:

-rw-r--r-- 1 vagrant vagrant 290190 Jan 26 15:26 Snow.jpg

以下是AFNetworking页面的示例代码:

NSMutableURLRequest *request = [[AFHTTPRequestSerializer serializer] multipartFormRequestWithMethod:@"POST" URLString:@"http://example.dev/upload" parameters:nil constructingBodyWithBlock:^(id<AFMultipartFormData> formData) {
        [formData appendPartWithFileURL:[NSURL fileURLWithPath:@"file://path/to/image.jpg"] name:@"upload" fileName:@"filename.jpg" mimeType:@"image/jpeg" error:nil];
    } error:nil];

AFURLSessionManager *manager = [[AFURLSessionManager alloc] initWithSessionConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration]];
NSProgress *progress = nil;

NSURLSessionUploadTask *uploadTask = [manager uploadTaskWithStreamedRequest:request progress:&progress completionHandler:^(NSURLResponse *response, id responseObject, NSError *error) {
    if (error) {
        NSLog(@"Error: %@", error);
    } else {
        NSLog(@"%@ %@", response, responseObject);
    }
}];

[uploadTask resume];

以下错误:

2015-01-26 15:16:09.683 digitaltest[8507:241970] Error: Error Domain=NSURLErrorDomain Code=-999 "cancelled" UserInfo=0x7fb223551a50 {NSErrorFailingURLKey=http://example.dev/api/v1/sendFile, NSLocalizedDescription=cancelled, NSErrorFailingURLStringKey=http://example.dev/api/v1/sendFile}

我可以从PHP端的自定义日志中看到iOS应用程序从未到达服务器。该网站在我的本地计算机和iPad模拟器上都可见,没有重定向,也不能通过SSL运行。

我在我现有的应用程序和一个全新的应用程序中尝试了示例代码,只需一个简单的hello world按钮,没有任何运气。

我该如何运作?

EDIT: As requested here is additional debug:

2015-01-26 20:38:58.211 digitaltest[9340:276782] fileDataURL: file:/Users/digital/Desktop/snow.jpg -- file:///
2015-01-26 20:38:58.223 digitaltest[9340:276782] error: Error Domain=NSCocoaErrorDomain Code=260 "The operation couldn’t be completed. (Cocoa error 260.)" UserInfo=0x7ff531757020 {NSFilePath=/file:/Users/digital/Desktop/snow.jpg, NSUnderlyingError=0x7ff53177bc90 "The operation couldn’t be completed. No such file or directory"}

这是输出证明文件在那里:

digital@nefarious-3 [08:39:59] [~]
-> % cd ~/Desktop
digital@nefarious-3 [08:40:05] [~/Desktop]
-> % LL
zsh: command not found: LL
digital@nefarious-3 [08:40:06] [~/Desktop]
-> % ll
total 1272
  0 drwxr-xr-x+  15 digital  staff   510B 26 Jan 20:35 .
  0 drwxr-xr-x+ 113 digital  staff   3.8K 26 Jan 20:40 ..
 24 -rw-r--r--@   1 digital  staff   8.0K 26 Jan 20:35 .DS_Store
  0 -rw-r--r--    1 digital  staff     0B 15 Jul  2013 .localized
  8 -rw-r--r--@   1 digital  staff   2.5K  5 Jan 15:29 Snow[0].jpg
  8 -rw-r--r--@   1 digital  staff   2.5K  5 Jan 15:29 Snow[1].jpg
  8 -rw-r--r--@   1 digital  staff   2.5K  5 Jan 15:29 Snow[2].jpg
  8 -rw-r--r--@   1 digital  staff   2.5K  5 Jan 15:29 Snow[3].jpg
  8 -rw-r--r--@   1 digital  staff   2.5K 26 Jan 20:35 snow.jpg

请注意时间戳。

1 个答案:

答案 0 :(得分:0)

由于沙盒,允许路径是通过使用域NSSearchPathForDirectoriesInDomains的函数NSUserDomainMask获得的。

有关可用应用程序目录的信息,请参阅About the iOS File System

以下是为名为“fileName”的文件创建文档目录路径的示例:

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths firstObject];
NSString *filePath = [documentsDirectory stringByAppendingPathComponent:fileName];

此外,允许从应用程序包中读取文件。