RestKit - 错误域代码 1001
Posted
技术标签:
【中文标题】RestKit - 错误域代码 1001【英文标题】:RestKit - Error Domain Code 1001 【发布时间】:2014-08-21 04:31:13 【问题描述】:好的,所以我已经查看了该网站上几乎所有其他问题,但无济于事。
这是我从 REST 服务返回的 JSON:
"errors" : ;
"result" :
"messagebody" : "Hello!";
"timestamp" : "2014-08-21T04:12:28.4689099+00:00";
;
"success" : ;
我正在尝试通过 RestKit v0.20.3 提取结果对象
这是我配置/执行的代码块:
- (void) configureRestKit
NSURL *cminstance = [NSURL URLWithString:@"http://<domain>"];
AFHTTPClient *cmclient = [[AFHTTPClient alloc] initWithBaseURL:cminstance];
RKObjectManager *objmgr = [[RKObjectManager alloc] initWithHTTPClient:cmclient];
RKObjectMapping *messageMap = [RKObjectMapping mappingForClass:[Message class]];
[messageMap addAttributeMappingsFromDictionary:@ @"messagebody" : @"messagebody", @"timestamp": @"timestamp"];
messageMap.forceCollectionMapping = YES;
RKResponseDescriptor *descriptor =
[RKResponseDescriptor
responseDescriptorWithMapping:messageMap
method:RKRequestMethodGET
pathPattern:@"/v1/app/e51cb2dd24af47a49232b942210e758d/text?f=test"
keyPath:@"result"
statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)];
[objmgr addResponseDescriptor:descriptor];
- (IBAction)helloButtonClicked:(id)sender
[[RKObjectManager sharedManager].HTTPClient setDefaultHeader:@"X-App-ApiKey" value:@"2c130c75dc9f4c2c8ef7c8753e8b7c56"];
NSLog(@"ResponseDescriptors %@", [[RKObjectManager sharedManager] responseDescriptors]);
[[RKObjectManager sharedManager] getObjectsAtPath:@"/v1/app/e51cb2dd24af47a49232b942210e758d/text?f=test" parameters:nil success:^(RKObjectRequestOperation *operation, RKMappingResult *mappingResult)
_Response.text = [mappingResult.dictionary objectForKey:@"messagebody"];
failure:^(RKObjectRequestOperation *operation, NSError *error)
_Response.text = @"Something went wrong.";
];
这是来自跟踪的错误:
2014-08-21 00:12:30.653 The-App[13924:3707] E restkit.network:RKObjectRequestOperation.m:208 GET 'http:///v1/app/e51cb2dd24af47a49232b942210e758d/text?f=test' (200 OK / 0 个对象)[请求=2.7297s 映射=0.0000s 总计=2.7365s]: 错误=错误域=org.restkit.RestKit.ErrorDomain 代码=1001 “没有响应描述符与加载的响应匹配。” UserInfo=0xb164380 NSErrorFailingURLStringKey=http:///v1/app/e51cb2dd24af47a49232b942210e758d/text?f=test, NSLocalizedFailureReason=从 URL 'http:///v1/app/e51cb2dd24af47a49232b942210e758 加载了 200 响应? ', 未能匹配所有 (0) 响应描述符:, NSLocalizedDescription=没有响应描述符与加载的响应匹配。, keyPath=null, NSErrorFailingURLKey=http:///v1/app/e51cb2dd24af47a49232b942210e758d/text?f=test, NSUnderlyingError= 0xb1641c0 “在搜索的关键路径中找不到可映射的对象表示。” response.body="success":,"errors":,"result":"messagebody":"Hello!","timestamp":"2014-08-21T04:12:28.4689099+00: 00"
这里有关于如何排除故障的任何想法吗?几个小时以来,我一直在努力解决这个问题,而谷歌并不是我的朋友。
编辑:响应描述符
2014-08-22 10:41:21.580 Apprenda-CloudMine-App[10987:60b] ResponseDescriptors (
"<RKResponseDescriptor: 0x17826c180 method=(GET) pathPattern=/v1/app/e51cb2dd24af47a49232b942210e758d/text?f=test keyPath=result statusCodes=200-299 : <RKObjectMapping:0x17826bfc0 objectClass=Message propertyMappings=(\n \"<RKAttributeMapping: 0x1780499f0 timestamp => timestamp>\",\n \"<RKAttributeMapping: 0x17804cf30 messagebody => messagebody>\"\n)>>"
)
谢谢! -克里斯
【问题讨论】:
在我看来这不像 JSON。这真的是您从服务中得到的回报吗?我想它应该看起来像 "errors": "result": "messagebody":"Hello!", "timestamp":"2014-08-21T04:12:28.4689099+00:00" , success:
实际上,您的错误消息表明这正是您要返回的内容。
另外,你能告诉我们NSLog(@"ResponseDescriptors %@", [[RKObjectManager sharedManager] responseDescriptors]);
的打印内容吗?
是的,这就是我从服务中得到的。我将使用响应描述符编辑我的问题。
是的,你是对的。上面的 json 被美化了。我将进行编辑以显示有效的 json(很好)。
【参考方案1】:
该错误表明您的请求和响应描述符之间的路径不匹配。很微妙,错误消息中的(0) response descriptors
还向我表明该路径没有响应描述符。有关 RestKit 路径不匹配的错误消息的更多信息,请参阅 this GitHub 问题。
那你为什么会遇到路径不匹配?毕竟,您的请求中的路径与响应描述符中的路径完全相同。看来您的问题很可能是响应描述符路径中指定的 GET 参数。您需要从响应描述符路径中删除 get 参数,因为它在技术上不是路径的一部分。
它应该是以下内容。
[RKResponseDescriptor
responseDescriptorWithMapping:messageMap
method:RKRequestMethodGET
pathPattern:@"/v1/app/e51cb2dd24af47a49232b942210e758d/text"
keyPath:@"result"
statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)];
感谢Flaviu Simihaian 意识到这一点。
【讨论】:
优秀。就是这样。谢谢你们!以上是关于RestKit - 错误域代码 1001的主要内容,如果未能解决你的问题,请参考以下文章
RestKit .20 RKRequestDescriptor postObject - (400-499) 中的预期状态代码,得到 200
错误:错误域=NSURLErrorDomain 代码=-1001“请求超时。”