【发布时间】: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(很好)。
标签: ios json restkit-0.20