Calling API之后不等待Response

时间:2013-05-03 12:57:36

标签: iphone ios

问题是我调用了megnto api,但是当api返回对象之前,所有其他语句都被执行了。

NSMutableArray *list=[Magento.service startSession];

    NSLog(@"Record is:%@",list);
我修改的

startSession方法是:

- (NSMutableArray *)startSession
{
 NSString *_sessionID;
    NSNumber *nsPage =[NSNumber  numberWithInt:1];
    NSNumber *nsData =[NSNumber  numberWithInt:10];
    NSMutableArray *listOfName = [[NSMutableArray alloc] init];
    NSArray *args = [NSArray arrayWithObjects:nsPage,nsData,nil ];
    @synchronized(self) {
  _sessionID = sessionID;
 }
 if (_sessionID != FAILED_SESSION)
  dispatch_group_enter(session_group);
 [client postPath:@"login" parameters:@{@"username": MAGENTO_USERNAME, @"apiKey": MAGENTO_API_KEY}  success:^(AFHTTPRequestOperation *operation, id responseObject) {
  sessionID = responseObject;



  dispatch_group_leave(session_group);

        [client postPath:@"call" parameters:@{@"sessionId":sessionID, @"resourcePath":@"callforprice_collection.getCallForPriceCollection",
         @"args":args
         } success:^(AFHTTPRequestOperation *operationData, id responseData) {

             NSLog(@"Response :  %@",responseData);
             [listOfName addObject:[responseData valueForKey:@"name"]];

         } failure:^(AFHTTPRequestOperation *operationData, NSError *error) {
             NSLog(@"Response is not get");
             sessionID = FAILED_SESSION;
         }];


        NSLog(@"got session %@", sessionID);
 } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
  sessionID = FAILED_SESSION;
 }];
    return  listOfName;

}

o / p

2013-05-03 06:27:16.272 CallForPrice[3120:c07] Record is: ()
2013-05-03 06:27:19.836 CallForPrice[3120:c07] got session 88ef34087a12809334ae3a0c839f85b6
** response that i have printed in method**
2013-05-03 06:27:22.048 CallForPrice[3120:c07] Response :  (
        {
        "callforprice_id" = 13;
        country = Austria;
        "created_time" = "2013-05-03 12:03:05";
        emailid = "indies.tester@gmail.com";
        message = hfhftrfygjh;
        name = "Richard Conover";
        "phone_no" = 8977896;
        "product_name" = Ottoman;
        "product_options" = "";
        "update_time" = "0000-00-00 00:00:00";
    },
        {
        "callforprice_id" = 12;
        country = "Antigua and Barbuda";
        "created_time" = "2013-05-03 12:01:24";
        emailid = "indies.tester@gmail.com";
        message = sdfsdfsdfwe;
        name = "Richard Conover";
        "phone_no" = 5645;
        "product_name" = Ottoman;
        "product_options" = "";
        "update_time" = "0000-00-00 00:00:00";
    },
        {
        "callforprice_id" = 11;
        country = Angola;
        "created_time" = "2013-05-03 11:58:51";
        emailid = "indies.tester@gmail.com";
        message = 6tyrtyryrty;
        name = "Kaitlyn Matheson";
        "phone_no" = 564564;
        "product_name" = Ottoman;
        "product_options" = "";
        "update_time" = "0000-00-00 00:00:00";
    },

startSession正在显示记录,实际上在调用响应之前打印的是NSLOG。如何解决这个问题。

3 个答案:

答案 0 :(得分:2)

1)在Magento.h中的所有导入后添加此行

typedef void(^completion)(NSArray *list);

2)在.h和.m

中更改方法签名
- (void)startSession:(completion) completion

3)在Magento.m中,使用此

修改您的方法
- (void)startSession:(completion) completion
{

        NSString *_sessionID;
        NSNumber *nsPage =[NSNumber  numberWithInt:1];
        NSNumber *nsData =[NSNumber  numberWithInt:10];
        NSMutableArray *listOfName = [[NSMutableArray alloc] init];
        NSArray *args = [NSArray arrayWithObjects:nsPage,nsData,nil ];
        @synchronized(self) {
            _sessionID = sessionID;
        }
        if (_sessionID != FAILED_SESSION)
            dispatch_group_enter(session_group);
        [client postPath:@"login" parameters:@{@"username": MAGENTO_USERNAME, @"apiKey": MAGENTO_API_KEY}  success:^(AFHTTPRequestOperation *operation, id responseObject) {
            sessionID = responseObject;



            dispatch_group_leave(session_group);

            [client postPath:@"call" parameters:@{@"sessionId":sessionID, @"resourcePath":@"callforprice_collection.getCallForPriceCollection",
             @"args":args
             } success:^(AFHTTPRequestOperation *operationData, id responseData) {

                 NSLog(@"Response :  %@",responseData);
                 [listOfName addObject:[responseData valueForKey:@"name"]];

                 completion(listOfName);

             } failure:^(AFHTTPRequestOperation *operationData, NSError *error) {
                 NSLog(@"Response is not get");
                 sessionID = FAILED_SESSION;
                 completion(nil);
             }];


            NSLog(@"got session %@", sessionID);
        } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
            sessionID = FAILED_SESSION;
            completion(nil);
        }];

}

4)在viewController.h中,声明一个全局变量来保存返回的名称,

@property(nonatomic, strong) NSArray *nameList;

// and in viewDidLoad method,
self.nameList = [[NSArray alloc] init];

5)将此代码片段放在viewDidLoad或

[Magento.service startSession:^(NSArray *list) {
    if(list){
        self.nameList = list;
        [self.tableView reloadData];
    }else self.nameList = [[NSArray alloc] init];
}];

6)使用self.nameList数组加载表

答案 1 :(得分:1)

首先分配NSMutableArray并确保[Magento.service renewSession]实际返回一个数组。

NSMutableArray *list = [NSMutableArray array];
list=[Magento.service renewSession];
//[Magento.service getCallForPriceData];
NSLog(@"Record is:%@",list);

答案 2 :(得分:0)

我不知道Magneto API,但我之前遇到过这种行为。这是一种异步方法。在startSession中,它将返回空列表,并进行异步调用(在不同的线程上)。在回复中,你对结果一无所知。 (Block存储本地引用,这就是为什么你可以添加一些东西)。尝试定义

startSessionWithCompletionBlock:(void(^)(NSArray* list))completionBlock; 

将函数和更改响应处理程序更改为:

NSLog(@"Response :  %@",responseData);
[listOfName addObject:[responseData valueForKey:@"name"]];
completionBlock(listOfName);

并致电

[Magento.service startSessionWithCompletionBlock:^(NSArray* list){
   NSLog(@"Record is:%@",list);
}];

这只会将第一个对象放在列表中并随之返回(只是为了显示它实际返回的内容)。您还需要定义一些逻辑来计算异步下载的项目。