简短的背景故事,我们之前的开发人员使用 ASIHTTPRequest 发出 POST 请求并从我们的 Web 服务中检索数据。由于未知的原因,我们应用程序的这一部分停止工作。似乎有足够的时间来证明未来并与 AFNetworking 合作。REST Web 服务在 CakePHP 框架上运行。
简而言之,我没有收到使用 AFNetworking 的请求响应字符串。
我知道 Web 服务有效,因为我能够成功发布数据并使用 curl 接收正确的响应: curl -d "data[Model][field0]=field0value&data[Model][field1]=field1value" https://example.com /api/class/function.plist
根据以前的开发人员的说明,我想出了以下内容。
#import "AFHTTPRequestOperation.h"
…
- (IBAction)loginButtonPressed {
NSURL *url = [NSURL URLWithString:@"https://example.com/api/class/function.plist"];
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
[request setHTTPMethod:@"POST"];
[request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];
[request setValue:[usernameTextField text] forHTTPHeaderField:@"data[User][email]"];
[request setValue:[passwordTextField text] forHTTPHeaderField:@"data[User][password]"];
AFHTTPRequestOperation *operation = [[[AFHTTPRequestOperation alloc] initWithRequest:request] autorelease];
[operation setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"operation hasAcceptableStatusCode: %d", [operation.response statusCode]);
NSLog(@"response string: %@ ", operation.responseString);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"error: %@", operation.responseString);
}];
[operation start];
}
输出:操作 hasAcceptableStatusCode:200 响应字符串:空白 plist 文件
尝试的解决方案 1: AFNetworking Post Request 建议的解决方案使用 AFHTTPRequestOperation 的一个功能,称为 operationWithRequest。但是,当我尝试使用上述解决方案时,我收到一条警告“类方法 '+operationWithRequest:completion:' not found (return type defaults to 'id'”
尝试的解决方案 2:NSURLConnection。输出:我可以打印成功日志消息,但不能打印响应字符串。*update - 返回空白 plist。
NSMutableURLRequest *req = [NSMutableURLRequest requestWithURL:url];
NSString *httpBodyData = @"data[User][email]=username@example.com&data[User][password]=awesomepassword";
[httpBodyData dataUsingEncoding:NSUTF8StringEncoding];
[req setHTTPMethod:@"POST"];
[req setHTTPBody:[NSData dataWithContentsOfFile:httpBodyData]];
NSHTTPURLResponse __autoreleasing *response;
NSError __autoreleasing *error;
[NSURLConnection sendSynchronousRequest:req returningResponse:&response error:&error];
// *update - returns blank plist
NSData *responseData = [NSURLConnection sendSynchronousRequest:req returningResponse:nil error:nil];
NSString *str = [[NSString alloc] initWithData:responseData encoding:NSUTF8StringEncoding];
NSLog(@"responseData %@",str);
if (error == nil && response.statusCode == 200) {
// Process response
NSLog(@"success");//returns success code of 200 but blank
NSLog(@"resp %@", response );
} else {
// Process error
NSLog(@"error");
}