gpt4 book ai didi

ios - RestKit 并作为 NSManagedObject 保存到 CoreData

转载 作者:技术小花猫 更新时间:2023-10-29 10:40:56 26 4
gpt4 key购买 nike

我正在使用 RestKit我想解析元素并将其保存到核心数据中。我有两个 json 文件:

第一(类别):

[
{
"cat_id": 3371,
"cat_name": "myName",
"image": 762
},
{
"cat_id": 3367,
"cat_name": "anotherName",
"image": 617
}
]

第二个(元素):

[
{
"art_id": "1",
"node": {
"author": "name"
},
"small_url": 0
},
{
"art_id": "12",
"node": {
"author": "anotherName"
},
"small_url": 0
}
]

所以基本思想是每个类别内部都有一些元素。所以这是我的 CoreData 结构: enter image description here

我已经下载了 restkit 示例并使用了 TwitterCoreData 示例。我的代码是:AppDelegeta.m

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
NSURL *baseURL = [NSURL URLWithString:@"http://globalURL.com"];
RKObjectManager *objectManager = [RKObjectManager managerWithBaseURL:baseURL];
NSManagedObjectModel *managedObjectModel = [NSManagedObjectModel mergedModelFromBundles:nil];
RKManagedObjectStore *managedObjectStore = [[RKManagedObjectStore alloc] initWithManagedObjectModel:managedObjectModel];
objectManager.managedObjectStore = managedObjectStore;

RKEntityMapping *categoryMapping = [RKEntityMapping mappingForEntityForName:@"Category" inManagedObjectStore:managedObjectStore];
categoryMapping.identificationAttributes = @[ @"catId" ];
[categoryMapping addAttributeMappingsFromDictionary:@{
@"cat_id": @"catId",
@"node.author": @"author",
}];

RKEntityMapping *elementsMapping = [RKEntityMapping mappingForEntityForName:@"Elements" inManagedObjectStore:managedObjectStore];
elementsMapping.identificationAttributes = @[ @"artId" ];
[elementsMapping addAttributeMappingsFromDictionary:@{
@"art_id": @"artId",
@"node.author": @"author",
}];
[elementsMapping addPropertyMapping:[RKRelationshipMapping relationshipMappingFromKeyPath:@"category" toKeyPath:@"category" withMapping:categoryMapping]];
RKResponseDescriptor *responseDescriptor = [RKResponseDescriptor responseDescriptorWithMapping:elementsMapping
pathPattern:nil
keyPath:nil
statusCodes:RKStatusCodeIndexSetForClass(RKStatusCodeClassSuccessful)];
[objectManager addResponseDescriptor:responseDescriptor];


[managedObjectStore createPersistentStoreCoordinator];
NSString *storePath = [RKApplicationDataDirectory() stringByAppendingPathComponent:@"MyCoreData.sqlite"];
NSString *seedPath = [[NSBundle mainBundle] pathForResource:@"MyCoreData" ofType:@"sqlite"];
NSError *error;
NSPersistentStore *persistentStore = [managedObjectStore addSQLitePersistentStoreAtPath:storePath fromSeedDatabaseAtPath:seedPath withConfiguration:nil options:nil error:&error];
NSAssert(persistentStore, @"Failed to add persistent store with error: %@", error);

// Create the managed object contexts
[managedObjectStore createManagedObjectContexts];

// Configure a managed object cache to ensure we do not create duplicate objects
managedObjectStore.managedObjectCache = [[RKInMemoryManagedObjectCache alloc] initWithManagedObjectContext:managedObjectStore.persistentStoreManagedObjectContext];



self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
// Override point for customization after application launch.
self.viewController = [[ViewController alloc] initWithNibName:@"ViewController" bundle:nil];
self.window.rootViewController = self.viewController;
[self.window makeKeyAndVisible];
return YES;
}

ViewController.m:

NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Elements"];
NSSortDescriptor *descriptor = [NSSortDescriptor sortDescriptorWithKey:@"artId" ascending:NO];
fetchRequest.sortDescriptors = @[descriptor];
[[RKObjectManager sharedManager] getObjectsAtPath:@"/detailaddress/:catId" parameters:nil success:^(RKObjectRequestOperation *operation, RKMappingResult *mappingResult) {
RKLogInfo(@"Load complete: Table should refresh...");
NSLog(@"%@",mappingResult);
[[NSUserDefaults standardUserDefaults] setObject:[NSDate date] forKey:@"LastUpdatedAt"];
[[NSUserDefaults standardUserDefaults] synchronize];
} failure:^(RKObjectRequestOperation *operation, NSError *error) {
RKLogError(@"Load failed with error: %@", error);
}];

映射日志显示“nil”。如何使用 restkit 将我的第一个 json(类别)中的数据保存到核心数据中?请记住,我还没有元素列表。

当我使用创建新文件创建 NEManagedObject 子类时,我得到了 Elements 类。

@interface Elements : NSManagedObject

@property (nonatomic, retain) NSNumber * artId;
@property (nonatomic, retain) NSString * author;
@property (nonatomic, retain) NSString * title;
@property (nonatomic, retain) NSManagedObject *category;

@end

最佳答案

在几个月前发布 .20 之前,我一直使用 RESTKit。老实说,虽然这个图书馆的初衷很好,但根据我的经验,它最终浪费的时间远远超过了拯救我的本意。

我已经将它与使用 .NET/MVC、PHP、python/Django/TastyPie 创建的 API 一起使用,并破解它以与 Twitter 一起做一些事情。这一切最终成为一个非常有趣的学术练习,但最终仅此而已。 RESTKit 的旧/新版本都假设了很多关于 API 响应请求的方式。

随着 .10 版本的发布,通过使用 Obj-C block 实现了相当多的可定制性。我可以拦截 RKRequest 的请求/响应,并且几乎可以覆盖 RESTKit 将要执行的任何操作。这看起来相当棒。现在随着 .20 版本的发布,一切都变得非常...聪明(聪明的代码通常不好)。

RK 现在不再试图保持通用性和可塑性,而是为您做各种“方便”的事情。这有效地剥夺了您将其塞入您的 API 所采用的任何(非理想化和现实的)形状的能力。在这一点上,我已经回到使用 AFNetworking 编写我所有的代码。 .我宁愿花额外的时间编写自己的解析代码,并且知道当我的单元测试通过时,我就完成了。不要花费数小时试图让 RK 记录有意义的错误消息。

RK 的另一个真正问题是它不考虑离线情况。它的设计假设您的应用程序始终在线,并且只是反射(reflect)了天空中的持久性商店。我的应用程序都在 iOS 设备上处理内容创建,这些设备在创建内容时可能在线,也可能不在线。这是我“定制”RK .10 的主要原因。当我看到 .20 中的变化时,我决定受够了,然后回到老方法做事。

也许我会编写我自己的 CRUD/RESTful 框架,因为我开始厌倦花时间使用非常专业的库,这些库尝试做所有事情,尽可能少地留给应用程序开发人员的责任。像这样的框架往往是瑞士军刀。它们在纸面上看起来真的很棒,它们可以做任何事情,然后您实际上尝试切割一些东西,但 Blade 太钝或折断了。好的软件很少能很好地完成某些事情,如果听起来好得令人难以置信,那很可能是真的。

关于ios - RestKit 并作为 NSManagedObject 保存到 CoreData,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14854641/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com