问题是我调用了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。如何解决这个问题。
答案 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);
}];
这只会将第一个对象放在列表中并随之返回(只是为了显示它实际返回的内容)。您还需要定义一些逻辑来计算异步下载的项目。