网络编程—多值参数和中文输出
2016-12-21 本文已影响0人
小白文_Vincent
文艺求关注.png
解析数据为NSString最后输出.png
JSON解析结果.png
似乎跟我们平时见到的字典样式还不一样,
最终效果.png
关注一下又不会怀孕.png
在开发当中,不免会遇到需要处理一些多值参数的情况,或者从后台拿到的数据输出中文的情况,接下来,我们详细讲解下,在开发中,遇到多值参数,以及中文输出,需要如何处理。
- 多值参数的正确处理方法
需求:如下图,查看热门城市的天气预报(参数可多选)
多值传递.png
// 首先,当我点击控制器的时候完成发送请求
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
// 01.确定请求URL
NSURL *url = [NSURL URLWithString:@""];
// 02.创建请求对象
NSURLRequest *request = [NSURLRequest requestWithURL:url];
// 03.发送请求
[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) {
// 04.解析数据
// 先将数据打印成NSString类型先来看一下,
NSLog(@"%@", [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]);
}];
}
得到的结果是这样:
解析数据为NSString最后输出.png
<b>注意:在01
处,确定请求URL的传值</b>
// 正确传值:http://120.25.226.186:32812/weather?place=Beijing&place=Guangzhou
// 错误传值:http://120.25.226.186:32812/weather?place=Beijing&Guangzhou 系统会自动忽略掉后面Guangzhou
okay,继续~~
在04
解析的时候,我们换一种方式解析:用JSON解析数据
// 04.解析JSON数据(注意:在开发中一般碰到的都是JSON数据解析)
// JSON --> OC对象
NSDictionary *dict = [NSJSONSerialization JSONObjectWithData:data options:kNilOptions error:nil];
最终答应结果:
JSON解析结果.png
注意:红色现在我们的代码还是存在一些问题的,在状态栏,我们得到的是一堆Unicode码,如何将Unicode码转化为中文呢?(如何控制字典的输出,重写系统的某个方法,覆盖掉系统原有的方法 — 给字典添加分类)
// 创建字典分类-- VtcExport(控制字典输出的分类)
// 重写系统的方法控制输出 (此方法控制程序中所有字典的输出)
- (NSString *)descriptionWithLocale:(id)locale indent:(NSUInteger)level {
//为了满足我们的需求,即:在用到Unicode转码的时候来到该方法,
// 便利字典,自己拼接字典中的key和value
// 自己拼接String
// 01.先创建可变String
NSMutableString *mutableString = [NSMutableString string];
// 02.从字典的最外层开始拼接
// 2.1拼接:{}
[mutableString appendString:@"{"];
// 2.2拼接 key --- value (通过self拿到字典)
/**
它就一个参数就是block,这个block携带了三个参数,这将要把dictionary里面的key和value每次一组传递到block,enumerateKeysAndObjectsUsingBlock会遍历dictionary并把里面的key和value一组一组的展示给你,每组都会执行这个block。这其实就是传递一个block到另一个方法,在这个例子里面它会带着特定参数被反复调用,直到找到一个ENOUGH的key,然后就会通过重新赋值那个BOOL *stop来停止运行,停止遍历同时停止调用block。
@param key 字典的Key
@param obj 字典的Value
@param stop 停止便利
*/
[self enumerateKeysAndObjectsUsingBlock:^(id _Nonnull key, id _Nonnull obj, BOOL * _Nonnull stop) {
[mutableString appendFormat:@"%@:", key];
[mutableString appendFormat:@"%@,", obj];
}];
[mutableString appendString:@"}"];
//删除逗号
// options:NSBackwardsSearch 从后往前的模式去搜索
NSRange range = [mutableString rangeOfString:@"," options:NSBackwardsSearch];
if (range.location != NSNotFound) {
[mutableString deleteCharactersInRange:range];
}
return mutableString;
}
重写字典的descriptionWithLocale方法之后,我们得到:
似乎跟我们平时见到的字典样式还不一样,
( )
在OC对象中代表数组,所以我们还需要从写NSArray的某个方法(descriptionWithLocale)
// 创建数组的分类-- VtcExport(控制数组输出的分类)
// 重写系统的方法控制输出 (此方法控制程序中所有字典的输出)
- (NSString *)descriptionWithLocale:(id)locale indent:(NSUInteger)level {
// 自己拼接String
// 01.先创建可变String
NSMutableString *mutableString = [NSMutableString string];
// 02.从数组的最外层开始拼接
[mutableString appendString:@"["];
// 2.2拼接 key --- value (通过self拿到字典)
[self enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
[mutableString appendFormat:@"%@,\n", obj];
}];
[mutableString appendString:@"]"];
//删除逗号
// options:NSBackwardsSearch 从后往前的模式去搜索
NSRange range = [mutableString rangeOfString:@"," options:NSBackwardsSearch];
if (range.location != NSNotFound) {
[mutableString deleteCharactersInRange:range];
}
return mutableString;
}
最终,我们得到的效果是:
最终效果.png
<b>注意:由于是重写的系统的方法,所以在使用的时候不需要包含分类的头文件,那我们可以简化一下代码,将我们重写的系统方法放在一个文件里面/同样也是可以的</b>
// 创建分类—Foundation+VtcExport.m
#import <Foundation/Foundation.h>
@implementation NSDictionary (VtcExport)
// 重写系统的方法控制输出 (此方法控制程序中所有字典的输出)
- (NSString *)descriptionWithLocale:(id)locale indent:(NSUInteger)level {
//为了满足我们的需求,即:在用到Unicode转码的时候来到该方法,
// 便利字典,自己拼接字典中的key和value
// 自己拼接String
// 01.先创建可变String
NSMutableString *mutableString = [NSMutableString string];
// 02.从字典的最外层开始拼接
// 2.1拼接:{}
[mutableString appendString:@"{"];
// 2.2拼接 key --- value (通过self拿到字典)
/**
它就一个参数就是block,这个block携带了三个参数,这将要把dictionary里面的key和value每次一组传递到block,enumerateKeysAndObjectsUsingBlock会遍历dictionary并把里面的key和value一组一组的展示给你,每组都会执行这个block。这其实就是传递一个block到另一个方法,在这个例子里面它会带着特定参数被反复调用,直到找到一个ENOUGH的key,然后就会通过重新赋值那个BOOL *stop来停止运行,停止遍历同时停止调用block。
@param key 字典的Key
@param obj 字典的Value
@param stop 停止便利
*/
[self enumerateKeysAndObjectsUsingBlock:^(id _Nonnull key, id _Nonnull obj, BOOL * _Nonnull stop) {
[mutableString appendFormat:@"%@:", key];
[mutableString appendFormat:@"%@,", obj];
}];
[mutableString appendString:@"}"];
//删除逗号
// options:NSBackwardsSearch 从后往前的模式去搜索
NSRange range = [mutableString rangeOfString:@"," options:NSBackwardsSearch];
if (range.location != NSNotFound) {
[mutableString deleteCharactersInRange:range];
}
return mutableString;
}
@end
@implementation NSArray (VtcExport)
- (NSString *)descriptionWithLocale:(id)locale indent:(NSUInteger)level {
// 自己拼接String
// 01.先创建可变String
NSMutableString *mutableString = [NSMutableString string];
// 02.从数组的最外层开始拼接
// 2.1拼接:[ ]
[mutableString appendString:@"["];
[self enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
[mutableString appendFormat:@"%@,\n", obj];
}];
[mutableString appendString:@"]"];
//删除逗号
// options:NSBackwardsSearch 从后往前的模式去搜索
NSRange range = [mutableString rangeOfString:@"," options:NSBackwardsSearch];
if (range.location != NSNotFound) {
[mutableString deleteCharactersInRange:range];
}
return mutableString;
}
好了,下次遇到如上问题,拷贝就可以了~
关注一下又不会怀孕.png