首页 > 学院 > 开发设计 > 正文

socket上传nsdictionary的json数据异常

2019-11-14 18:11:23
字体:
来源:转载
供稿:网友

异常情况如下:按照正常的写法,将上传对数据封装在nsdictionary里,然后检验是否符合json格式化,调用系统的json序列化方法将nsdictionary转化为json数据然后上传,

异常结果如下:,后台只能收到收到nsdictionary的第一个{,后测试数据从nsdictionary的第一个{断开了

由于控制台打印的nsdictioanry数据如下

故猜测上传数据时"/n"作为了数据的分隔符被切断了,所以将nsdictionary转化为nsstring并且将"/n"替换为空格然后发现数据无法上传,最后追加了"/n"到nsstring末端,上传成功

完整代码如下:

#PRagma mark - GCDAsyncSocketDelegate
/** *  链接成功 * *  @param sock sock实例 *  @param host ip *  @param port 端口 */-(void)socket:(GCDAsyncSocket *)sockdidConnectToHost:(NSString *)host         port:(uint16_t)port{    NSLog(@"didConnectToHost");    //    gpstype:2015    //        name:账号    //        pswd:密码        NSLog(sock.isConnected?@"YES":@"NO");    if (sock.isConnected)    {/*
//nsstring上传需要加"/n"分隔符方可上传成功
[sock writeData:[@"ABCABCABCABCABCABC/n" dataUsingEncoding:NSUTF8StringEncoding] withTimeout:-1 tag:0]; */ NSDictionary* nsDictionaryUser=@{@"gpsinfo":@"Gpsinfo",@"pswd":self.passWord,@"other":@"666",@"gpstype":@2015,@"name":self.name}; if ([NSJSONSerialization isValidJSONObject:nsDictionaryUser]) { NSLog(@"isValidJSONObject"); NSError* error;
//先转nsdata再转nsstring是为了保证nsdictionary格式不变 NSData
*nsDataUser= [NSJSONSerialization dataWithJSONObject:nsDictionaryUser options:NSJSONWritingPrettyPrinted error:&error]; NSString* json=[[NSString alloc] initWithData:nsDataUser encoding:NSUTF8StringEncoding];// NSLog(@"nsDictionaryUser:%@",json); json=[json stringByReplacingOccurrencesOfString:@"/n" withString:@""];
//空格根据情况可以不去掉 json
=[json stringByReplacingOccurrencesOfString:@" " withString:@""]; json=[json stringByAppendingString:@"/n"]; NSLog(@"json:%@",json); [sock writeData:[json dataUsingEncoding:NSUTF8StringEncoding] withTimeout:-1 tag:0]; //保持读取的长连接 [sock readDataWithTimeout:-1 tag:0]; if (error) { NSLog(@"localizedDescription:%@",[error localizedDescription]); NSLog(@"localizedFailureReason:%@",[error localizedFailureReason]); } else { } } } }

 
数据上传成功了,后台可以根据数据返回数据了


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表