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 api目标c调用Web服务时出错

RestKit .20 RKRequestDescriptor postObject - (400-499) 中的预期状态代码,得到 200

RestKit 的词法解析器问题

错误:错误域=NSURLErrorDomain 代码=-1001“请求超时。”

错误:错误域=NSURLErrorDomain 代码=-1001 “请求超时。”

错误:错误域=NSURLErrorDomain 代码=-1001“请求超时。”