我无法在 Xcode 中将 JSON 格式的时间戳转换为 NSDate。
例如,我从 RESTful Web 服务返回以下格式化时间戳:“/Date(1369835402000)/”。
[编辑]
进行此编辑是为了清楚我实际返回的值和我传入的值:
当我将上述时间戳转换为 NSDate 时,我得到的时间如下:
如您所见,即使我没有设置时区,返回的日期也比实际日期早 1 小时。
我现在使用以下方法将时间戳转换为日期:
- (NSDate*) getDateFromJSON:(NSString *)dateString
{
// Expect date in this format "/Date(1369835402000)/"
int startPos = [dateString rangeOfString:@"("].location+1;
int endPos = [dateString rangeOfString:@")"].location;
NSRange range = NSMakeRange(startPos,endPos-startPos);
unsigned long long milliseconds = [[dateString substringWithRange:range] doubleValue];
NSLog(@"%llu",milliseconds);
NSTimeInterval interval = milliseconds/1000;
return [NSDate dateWithTimeIntervalSince1970:interval];
}
但它仍然提前 1 小时返回值。
[编辑]
从 NSLog 请求的 DUMP 在下面加上创建它的代码:
- (NSDate*) getDateFromJSON:(NSString *)dateString
{
// Expect date in this format "/Date(1369835402000)/"
int startPos = [dateString rangeOfString:@"("].location+1;
int endPos = [dateString rangeOfString:@")"].location;
NSRange range = NSMakeRange(startPos,endPos-startPos);
unsigned long long milliseconds = [[dateString substringWithRange:range] longLongValue];
NSTimeInterval interval = milliseconds/1000;
NSLog(@"%f", interval);
NSLog(@"%@", [NSDate dateWithTimeIntervalSince1970:interval]);
interval -= 3600;
return [NSDate dateWithTimeIntervalSince1970:interval];
}
样品转储:
2013-05-30 09:58:47.616 Log[13734:907] 1365693200.000000
2013-05-30 09:58:47.619 Log[13734:907] 2013-04-11 15:13:20 +0000
2013-05-30 09:58:47.620 Log[13734:907] 2013-04-11 14:13:20 +0000
2013-05-30 09:58:47.621 Log[13734:907] 1358157335.000000
2013-05-30 09:58:47.622 Log[13734:907] 2013-01-14 09:55:35 +0000
2013-05-30 09:58:47.622 Log[13734:907] 2013-01-14 08:55:35 +0000
2013-05-30 09:58:47.628 Log[13734:907] 1365684042.000000
2013-05-30 09:58:47.629 Log[13734:907] 2013-04-11 12:40:42 +0000
2013-05-30 09:58:47.630 Log[13734:907] 2013-04-11 11:40:42 +0000
2013-05-30 09:58:47.632 Log[13734:907] 1358157374.000000
2013-05-30 09:58:47.632 Log[13734:907] 2013-01-14 09:56:14 +0000
2013-05-30 09:58:47.633 Log[13734:907] 2013-01-14 08:56:14 +0000
2013-05-30 09:58:47.638 Log[13734:907] 1365684238.000000
2013-05-30 09:58:47.639 Log[13734:907] 2013-04-11 12:43:58 +0000
2013-05-30 09:58:47.640 Log[13734:907] 2013-04-11 11:43:58 +0000
第一行是区间输出。
其次是使用 dateWithTimeInteralSince1970 进行转换后,显示自动添加的 1 小时。
第三是我调用它的函数的返回值 - 显示手动减去的小时(-3600)。