我正在尝试发送一个NSArray *appData
,因为它NSArray
包含一个NSDictionary
(请参阅下面的数据布局)但是当我收到时Array
,PHP
所有值NSDictionary
都作为单个数组发送,而不是以它们发送的相同格式(请参阅下面的 PHP 日志数据)。
中的所有其他值NSDictionary* params
都已正确发送和接收。
这是我的代码中的错误还是问题?如果后者是问题,我做错了什么?
注意:我使用的是最新版本AFNetworking
编辑:
作为@dpassage
答案,我进行了编辑以包括更广泛的测试并将信息发送为form-data
. 测试的有趣之处在于,@"test"
发送到服务器的参数显示很好,PHP
但不是@"share":appData
很奇怪
- (void) checkForUploadEligibility {
NSArray* dates = [myModel getStatsMaxAndMinResults];
if ( dates ) {
NSDictionary* d = [dates objectAtIndex:0];
NSDate* minDate = d[@"minDate"];
NSDate* maxDate = d[@"maxDate"];
NSTimeInterval secondsBetween = [maxDate timeIntervalSinceDate:minDate];
int numberOfDays = secondsBetween / 86400;
numberOfDays = abs(numberOfDays);
if (numberOfDays >= 0) {
myUser = [myModel getCurrentUser];
if ( myUser.userWebID && myUser.authToken ) {
NSArray* appData = [myModel getAllStatsData];
if (!appData) {
return;
}
NSDictionary* params = @{ @"userID": myUser.userWebID,
@"authCode": myUser.authToken,
@"interact":@{@"action":@"uploadAppStats",
@"actionTarget":@"uploadAppStats"},
@"share":appData,
@"test":@[@{@"test1":@{@"test2":@"test2"}},@{@"test3":@"test3"}]
};
[myShare uploadStats:params statsData:appData];
}
}
}
}
- (void) uploadStats:(NSDictionary*)params statsData:(NSArray *)statsData {
NSLog(@"count %i, %@",[statsData count],statsData);
NSURL *url = [[NSURL alloc]initWithString:sysURL];
AFHTTPClient *httpClient = [[AFHTTPClient alloc]initWithBaseURL:url];
NSURLRequest *request = [httpClient requestWithMethod:@"POST" path:sysAppURLPath parameters:params];
AFJSONRequestOperation *operation = [AFJSONRequestOperation JSONRequestOperationWithRequest:request
success:^(NSURLRequest *request, NSHTTPURLResponse *response, id JSON){
NSLog(@"a: Inside the success block %@",JSON);
if ( [JSON objectForKey:@"ok"] ) {
// [myModel deleteAllStatsData:statsData];
}
}
failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, id JSON){
NSLog(@"json text is: %@", JSON);
NSLog(@"Request failed with error: %@, %@", error, error.userInfo);
}];
// Debug HTTP response
BOOL dbug = YES;
if (dbug) {
[operation setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"HTTP r: %@", operation.responseString);
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"HTTP Error: %@", operation.responseString);
}
];
}
[operation start];
}
错误日志
count 5, (
{
date = "2013-09-09 16:10:51 +0000";
name = selectRoutine;
shared = 0;
timeSpent = 3;
},
{
date = "2013-09-09 16:10:53 +0000";
name = manageExercises;
shared = 0;
timeSpent = 1;
}, // MORE.....
HTTP Error: array(24) {
multipart/form-data; boundary=Boundary+0xAbCdEfGbOuNdArY
array(5) {
["authCode"]=>
string(32) "e186cdd000a741ef76555009d7e86d80"
["interact"]=>
array(2) {
["action"]=>
string(14) "uploadAppStats"
["actionTarget"]=>
string(14) "uploadAppStats"
}
["share"]=>
array(15) {
[0]=>
array(1) {
["date"]=>
string(19) "2013-09-09 19:52:31"
}
[1]=>
array(1) {
["name"]=>
string(13) "selectRoutine"
}
[2]=>
array(1) {
["timeSpent"]=>
string(1) "3"
}
[3]=>
array(1) {
["date"]=>
string(19) "2013-09-09 19:52:33"
}
[4]=>
array(1) {
["name"]=>
string(14) "manageRoutines"
}
[5]=>
array(1) {
["timeSpent"]=>
string(1) "2"
}
[6]=>
array(1) {
["date"]=>
string(19) "2013-09-09 22:24:31"
}
[7]=>
array(1) {
["name"]=>
string(13) "selectRoutine"
}
[8]=>
array(1) {
["timeSpent"]=>
string(2) "19"
}
[9]=>
array(1) {
["date"]=>
string(19) "2013-09-09 22:24:45"
}
[10]=>
array(1) {
["name"]=>
string(14) "manageRoutines"
}
[11]=>
array(1) {
["timeSpent"]=>
string(2) "14"
}
[12]=>
array(1) {
["date"]=>
string(19) "2013-09-09 22:25:58"
}
[13]=>
array(1) {
["name"]=>
string(15) "manageExercises"
}
[14]=>
array(1) {
["timeSpent"]=>
string(2) "73"
}
}
["test"]=>
array(2) {
[0]=>
array(1) {
["test1"]=>
array(1) {
["test2"]=>
string(5) "test2"
}
}
[1]=>
array(1) {
["test3"]=>
string(5) "test3"
}
}
["userID"]=>
string(24) "5224b598f86f265801000008"
}