RestKit 0.20 - CoreData: ошибка: не удалось вызвать назначенный инициализатор для класса NSManagedObject
Я столкнулся с новой проблемой, которую я никак не могу обойти... Вот мой код RestKit, следующий примеру Twitter Core Data:
//
// RESTKIT
//
// restkit object manager
NSString *baseURL = @"http://test1.website.com";
RKObjectManager *objectManager = [RKObjectManager managerWithBaseURL:[NSURL URLWithString:baseURL]];
// enable activity indicator
[AFNetworkActivityIndicatorManager sharedManager].enabled = YES;
// managed object model
NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"AppName" withExtension:@"momd"];
NSManagedObjectModel *managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
// NSLog(@"managed object model: %@", managedObjectModel);
// managed object store
RKManagedObjectStore *managedObjectStore = [[RKManagedObjectStore alloc] initWithManagedObjectModel:managedObjectModel];
objectManager.managedObjectStore = managedObjectStore;
// NSLog(@"managed object store: %@", managedObjectStore);
// persistent store
NSError *error;
NSString *storePath = [RKApplicationDataDirectory() stringByAppendingPathComponent:@"AppName.sqlite"];
NSPersistentStore *persistentStore = [managedObjectStore addSQLitePersistentStoreAtPath:storePath fromSeedDatabaseAtPath:nil withConfiguration:nil options:nil error:&error];
if (error) {
NSLog(@"unresolved error %@, %@", error, [error userInfo]);
abort();
}
// NSLog(@"persistent store coordinator: %@", managedObjectStore.persistentStoreCoordinator);
// NSLog(@"persistent store: %@", persistentStore);
// managed object contexts
[managedObjectStore createManagedObjectContexts];
// NSLog(@"managed object context: %@", managedObjectStore.mainQueueManagedObjectContext);
// managed object cache
managedObjectStore.managedObjectCache = [[RKInMemoryManagedObjectCache alloc] initWithManagedObjectContext:managedObjectStore.mainQueueManagedObjectContext];
// NSLog(@"mangaged object cache: %@", managedObjectStore.managedObjectCache);
//
// entity mapping
//
// album entity mapping
RKEntityMapping *albumEntityMapping = [RKEntityMapping mappingForEntityForName:@"Album" inManagedObjectStore:managedObjectStore];
albumEntityMapping.identificationAttributes = @[ @"identifier" ];
[albumEntityMapping addAttributeMappingsFromDictionary:@{ @"title" : @"title" }];
//
// response descriptor
//
// album response descriptor
[objectManager addResponseDescriptor:[RKResponseDescriptor responseDescriptorWithMapping:albumEntityMapping pathPattern:[NSString stringWithFormat:@"/albums/display/%@/%@", userInfo[@"userID"], userInfo[@"apiKey"]] keyPath:nil statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)]];
Я запрашиваю информацию из API через класс UITableViewController:
- (void)loadObjectsFromResourcePath:(NSString *)resourcePath;
{
[[RKObjectManager sharedManager] getObjectsAtPath:resourcePath parameters:nil success:^(RKObjectRequestOperation *operation, RKMappingResult *mappingResult) {
NSLog(@"mapping result: %@", [mappingResult array]);
[self stopLoading];
} failure:^(RKObjectRequestOperation *operation, NSError *error) {
NSLog(@"error: %@", error);
[self stopLoading];
}];
}
Однако с этим кодом я получаю следующие ошибки:
2012-12-05 17:08:14.830 AppName Alpha[1310:907] I restkit:RKLog.m:34 RestKit logging initialized...
2012-12-05 17:08:15.107 AppName Alpha[1310:907] resource path: albums/display/102/drrrbSAt6RFLsgHaKiiB6kBIyYRyzxLYinL84Kba
2012-12-05 17:08:15.113 AppName Alpha[1310:907] I restkit.support:RKMIMETypeSerialization.m:115 JSON Serialization class 'RKNSJSONSerialization' detected: Registering for MIME Type 'application/json
2012-12-05 17:08:15.118 AppName Alpha[1310:1603] I restkit.network:RKHTTPRequestOperation.m:141 GET 'http://test1.AppName.com/albums/display/102/drrrbSAt6RFLsgHaKiiB6kBIyYRyzxLYinL84Kba'
2012-12-05 17:08:15.122 AppName Alpha[1310:907] error (null), (null)
2012-12-05 17:08:35.333 AppName Alpha[1310:3e13] I restkit.network:RKHTTPRequestOperation.m:158 GET 'http://test1.AppName.com/albums/display/102/drrrbSAt6RFLsgHaKiiB6kBIyYRyzxLYinL84Kba' (200)
2012-12-05 17:08:35.351 AppName Alpha[1310:1507] CoreData: error: Failed to call designated initializer on NSManagedObject class 'AppName Album'
2012-12-05 17:08:35.355 AppName Alpha[1310:1507] *** Terminating app due to uncaught exception 'NSUnknownKeyException', reason: '[<AppName 0x1c579380> valueForUndefinedKey:]: the entity (null) is not key value coding-compliant for the key "Title".'
*** First throw call stack:
(0x39e503e7 0x38ea9963 0x39e500d5 0x371f8d81 0x3276cc1d 0xbf545 0xc00f5 0xc0ab9 0xc44c5 0x32791299 0xb738b 0xb6e5f 0xb7ca5 0xb8343 0xb895b 0x32791299 0xf96ef 0xf8c4b 0x32791299 0x328097f7 0x32c38793 0x32c3c657 0x32c3c7d9 0x3312a7f1 0x3312a684)
libc++abi.dylib: terminate called throwing an exception
Вы можете взять пик у возвращенного объекта JSON здесь: http://test1.appname.com/albums/display/102/drrrbSAt6RFLsgHaKiiB6kBIyYRyzxLYinL84Kba
2 ответа
Это указывает на то, что была предпринята попытка создать объект без вызова соответствующего инициализатора Core Data, что, вероятно, означает, что вы получаете RKObjectRequestOperation
экземпляр вместо RKManagedObjectRequestOperation
,
Я подозреваю, что дескриптор ответа не соответствует URL-адресу, что заставляет его выбрать неправильный тип операции запроса объекта. Вы можете проверить это, поставив точку останова в appropriateObjectRequestOperationWithObject:method:path:parameters:
в строках, которые читают:
NSArray *matchingDescriptors = RKFilteredArrayOfResponseDescriptorsMatchingPath(self.responseDescriptors, requestPath);
BOOL containsEntityMapping = RKDoesArrayOfResponseDescriptorsContainEntityMapping(matchingDescriptors);
BOOL isManagedObjectRequestOperation = (containsEntityMapping || [object isKindOfClass:[NSManagedObject class]]);
Именно эта логика отвечает за выбор типа создаваемой операции. Проверьте, что matchingDescriptors
содержит ожидаемый вами дескриптор ответа и затем проверяет значения следующих двух логических значений. Я думаю, что RKFilteredArrayOfResponseDescriptorsMatchingPath
не возвращает то, что вы ожидаете.
Прочитайте документацию по классу для RKObjectManager, в которой разъясняется, как обрабатывать сетевую обработку AF для базового URL. Если бы я прочитал это в первую очередь, я бы сэкономил немного времени, а также не делал неуместных комментариев относительно путей в примерах RestKit.
Имелись проблемы с сопоставлением сочетаний сопоставлений объектов и сущностей, в том числе ряда сопоставлений объектов с путем с нулевым ключом и различными URL-адресами, и нашел этот ответ очень полезным для определения причины описанной ниже проблемы, которая, возможно, способствовала тому, что другие испытывали аналогичные проблемы.