假设我想使用json
向服务器发送请求{ "begin_session" : { "info" : "this is some info" } }
我期待json回复:
{ "token" : "this is a token", "a_objects" : [
{ "name" : "name of first a_object", "b_objects" : [
{ "name" : "name of first b_object", "type" : "some type value", "id" : "123" },
{ "name" : "name of second b_object", "type" : "some other type value", "id" : "124" }
], "id" : "id of first a_object" },
{ "name" : "name of second a_object", "b_objects" : [
{ "name" : "name of first b_object", "type" : "some type value", "id" : "123" },
{ "name" : "name of third b_object", "type" : "some third type value" , "id" : "125" },
], "id" : "id of second a_object" }
] }
我想暂时存储“令牌”并将a_object持久存储在核心数据中。这是我应该怎么做的整个过程?首先,我设置了对象:
@interface LoginToken : NSObject
@property (nonatomic, copy) NSString *token;
@end
@interface AObject : NSManagedObject
@property (nonatomic, retain) NSString *name;
@property (nonatomic, retain) NSSet *bObjects;
@property (nonatomic, retain) NSString *aObjectId;
@end
@implementation AObject
@dynamic name; @dynamic bObjects; @dynamic aObjectId;
@end
@interface BObject : NSManagedObject
@property (nonatomic, retain) NSString *name;
@property (nonatomic, retain) AObject *aObject;
@property (nonatomic, retain) NSString *type;
@property (nonatomic, retain) NSString *bObjectId;
@end
@implementation BObject
@dynamic name; @dynamic aObject; @dynamic type; @dynamic bObjectId;
@end
这些是请求参数:
NSDictionary *params = @{"begin_session":@{@"info":@"this is some info"}};
然后我设置了映射:
RKObjectMapping *tokenMapping = [RKObjectMapping mappingForClass:[LoginToken class]];
[tokenMapping addAttributeMappingsFromArray:@[@"token"]];
RKResponseDescriptor *tokenResponseDescriptor = [RKResponseDescriptor responseDescriptorWithMapping:tokenMapping pathPattern:nil keyPath:@"token" statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)];
RKEntityMapping *bObjectMapping = [RKEntityMapping mappingForEntityForName:@"BObject" inManagedObjectStore:objectManager.managedObjectStore];
[bObjectMapping addAttributeMappingsFromDictionary:@{@"name":@"name",@"type":@"type", @"id":@"bObjectId"}];
bObjectMapping.identificationAttributes = @[@"bObjectId"];
RKEntityMapping *aObjectMapping = [RKEntityMapping mappingForEntityForName:@"AObject" inManagedObjectStore:objectManager.managedObjectStore];
[aObjectMapping addAttributeMappingsFromDictionary:@{@"name":@"name",@"id":@"aObjectId"}];
[aObjectMapping addPropertyMapping:[RKRelationshipMapping relationshipMappingFromKeyPath:@"b_objects" toKeyPath:@"bObjects" withMapping:bObjectMapping]];
aObjectMapping.identificationAttributes = @[@"aObjectId"];
假设objectManager
是正确配置的RKObjectManager。我设置了响应描述符:
RKResponseDescriptor *tokenResponseDescriptor = [RKResponseDescriptor responseDescriptorWithMapping:tokenMapping pathPattern:nil keyPath:@"token" statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)];
RKResponseDescriptor *aObjectResponseDescriptor = [RKResponseDescriptor responseDescriptorWithMapping:aObjectMapping pathPattern:nil keyPath:@"a_objects" statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)];
[objectManager addResponseDescriptorsFromArray:@[tokenResponseDescriptor, aObjectResponseDescriptor]];
最后我会提出要求:
[objectManager getObjectsAtPath:@"path" parameters:params success:^(RKObjectRequestOperation *operation, RKMappingResult *mappingResult) {
LoginToken *token = [mappingResult firstObject]; // use this token transiently
// coredata objects are auto saved
} failure:^(RKObjectRequestOperation *operation, NSError *error) {
// handle error
}];
有没有什么我需要注意的事实,这是否是正确的方法呢?另外,如何设置从BObject到AObject的反向关系......?
答案 0 :(得分:0)
只要您的CoreData文件具有正确配置的关系(根据您的对象头文件看起来是正确的),则反向关系由映射器处理。否则,它应该按原样工作。
请注意,令牌对象也将保留在CoreData中,因此您可能必须删除它们所需的行为。