2

Restkitと同時に2つのリクエストを送信していて、両方から応答が返ってきましたが、オブジェクトを受信するのは1つのリクエストだけです。それらを1つずつ送信すると、オブジェクトローダーはすべてのオブジェクトを受け取ります。

最初のリクエスト:

self.firstObjectManager = [RKObjectManager sharedManager];
[self.firstObjectManager loadObjectsAtResourcePath:[NSString stringWithFormat: @"/%@.json", subUrl] usingBlock:^(RKObjectLoader *loader){
    [loader.mappingProvider setObjectMapping:designArrayMapping forKeyPath:@""];
    loader.userData = @"design";
    loader.delegate = self;
    [loader sendAsynchronously];
}];

二つ目の要求:

self.secondObjectManager = [RKObjectManager sharedManager];
[self.secondObjectManager loadObjectsAtResourcePath:[NSString stringWithFormat: @"/%@.json", subUrl] usingBlock:^(RKObjectLoader *loader){
    [loader.mappingProvider setObjectMapping:designerMapping forKeyPath:@""];
    loader.userData = @"designer";
    loader.delegate = self;
    [loader sendAsynchronously];
}];

私のオブジェクトローダー:

-(void)objectLoader:(RKObjectLoader *)objectLoader didLoadObjects:(NSArray *)objects
{
    //NSLog(@"This happened: %@", objectLoader.userData);
    if (objectLoader.userData == @"design") {
        NSLog(@"Design happened: %i", objects.count);
    }else if(objectLoader.userData == @"designer"){
        NSLog(@"designer: %@", [objects objectAtIndex:0]);
    }

}

私の反応:

2012-11-18 14:36:19.607 RestKitTest5[14220:c07] Started loading of request: designer
2012-11-18 14:36:22.575 RestKitTest5[14220:c07] I restkit.network:RKRequest.m:680:-[RKRequest updateInternalCacheDate] Updating cache date for request <RKObjectLoader: 0x95c3160> to 2012-11-18 19:36:22 +0000
2012-11-18 14:36:22.576 RestKitTest5[14220:c07] response code: 200
2012-11-18 14:36:22.584 RestKitTest5[14220:c07] Design happened: 0
2012-11-18 14:36:22.603 RestKitTest5[14220:c07] I restkit.network:RKRequest.m:680:-[RKRequest updateInternalCacheDate] Updating cache date for request <RKObjectLoader: 0xa589b50> to 2012-11-18 19:36:22 +0000
2012-11-18 14:36:22.605 RestKitTest5[14220:c07] response code: 200
2012-11-18 14:36:22.606 RestKitTest5[14220:c07] designer: <DesignerData: 0xa269fc0>

更新:ベースURLの設定

RKURL *baseURL = [RKURL URLWithBaseURLString:@"http://iphone.meer.li"];
[RKObjectManager setSharedManager:[RKObjectManager managerWithBaseURL:baseURL]];

解決

問題は、両方のオブジェクトマネージャーに共有マネージャーを使用したため、次のことを行うことになりました。

RKURL *baseURL = [RKURL URLWithBaseURLString:@"http://iphone.meer.li"];
RKObjectManager *myObjectManager = [[RKObjectManager alloc] initWithBaseURL:baseURL];
self.firstObjectManager = myObjectManager;

と:

RKURL *baseURL = [RKURL URLWithBaseURLString:@"http://iphone.meer.li"];
RKObjectManager *myObjectManager = [[RKObjectManager alloc] initWithBaseURL:baseURL];
self.secondObjectManager = myObjectManager;
4

1 に答える 1

2

ロードにブロック構文を使用し、

self.secondObjectManager = [RKObjectManager sharedManager];
[self.secondObjectManager loadObjectsAtResourcePath:[NSString stringWithFormat: @"/%@.json", subUrl] usingBlock:^(RKObjectLoader *loader){
    [loader.mappingProvider setObjectMapping:designerMapping forKeyPath:@""];
    loader.userData = @"designer";
     loader.onDidLoadObjects = ^(NSArray *objects){
         NSLog(@"Loaded objects %@", objects);
      };
     loader.onDidFailedWithError = ^(NSError *error){
        NSLog(@"Failed with error %@", error.userInfo);
   }
}];

編集

独自のオブジェクトマネージャーを使用して保持し、このように使用します。

sharedManagerを使用せず、代わりにそれを割り当て/初期化し、オブジェクトストアを提供して参照してください。これがお役に立てば幸いです。

[self.objectManager loadObjectsAtResourcePath:resourcePath usingBlock:^(RKObjectLoader *loader){
        [loader.mappingProvider setMapping:[MyClass mapping] forKeyPath:@""];
        loader.onDidLoadObjects = ^(NSArray *objects){

        };
        loader.onDidLoadResponse = ^(RKResponse *response){
            NSLog(@"Loaded response %@", response.bodyAsString);
        };
        loader.onDidFailLoadWithError = ^(NSError *error){
            NSLog(@"Error occurred ... %@", error.userInfo);

        };
    }];
于 2012-11-18T21:21:56.743 に答える