iOS:网络编程中三个数据解析协议HTTP、XML、JSON的详细介绍
网络编程:HTTP协议、XML数据协议、JSON数据协议:
等待网络处理中……
// 服务器开始返回数据
// 收到服务器返回的数据,本方法会被调用多次
- (void)connection:didReceiveData:
// 数据接收完毕,做数据的最后处理
// 网络连接错误
- (void)connection:didFailWithError:
// 发送数据给服务器,POST 请求使用此方法
- (void)connection:didSendBodyData:totalBytesWritten: totalBytesExpectedToWrite:
unsigned long enconding = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000)
4、GET请求步骤——1. 地址 2.请求 3.连接 4.启动
(1)定义URL:
sendSynchronousRequest:request returningResponse:&response error:&error
sendAsynchronousRequest:request queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *error)
•服务器传输回来的数据,设置要用的编码类型,将汉字GBK编码转为国际通用编码UTF-8编码:
unsigned long encoding = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);
※知识拓展:
从 GBK 转到 UTF-8 (上面的例子可作为一个成功案例)
用 NSStringEncoding enc = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000) ,然后就可以用initWithData:encoding来实现。
从 UTF-8 转到 GBK
CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000),得到的enc却是kCFStringEncodingInvalidId。
没关系,试试 NSData *data=[nsstring dataUsingEncoding:-2147482063];
注意:必须使用kCFStringEncodingGB_18030_2000这个字符集,那个kCFStringEncodingGB_2312_80试了也不行。
成功案例: 将uif-8格式(xcode默认的)的字符串str_selectedLeiXing 转换为GBK格式的strGBK,如下所示:
NSData *data = [str_selectedLeiXing dataUsingEncoding:-2147482063];
NSString *strGBK = [[NSString alloc]initWithData:data encoding:-2147482063];
以上代码的实现,不需要添加任何附加开发包。
XML:
1、介绍:
可扩展标记语言
用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言
SAX(Simple API for XML)只能读,不能修改,只能顺序访问,适合解析大型XML,解析速度快常应用于处理大量数据的XML,实现异构系统的数据访问,实现跨平台从文档的开始通过每一节点移动,定位一个特定的节点
不仅能读,还能修改,而且能够实现随机访问,缺点是解析速度慢,适合解析小型文档一般应用与小型的配置XML,方便操作为载入到内存的文档节点建立类型描述,呈现可横向移动、潜在巨大的树型结构在内存中生成节点树操作代价昂贵
<1>. 创建NSXMLParser实例,并传入从服务器接收的XML数据<2>. 定义解析器代理<3>. 解析器解析<4.. 通过解析代理方法完成XML数据的解析
4、NSXMLParser解析的NSXMLParserDelegate协议代理方法:
// 1. 开始解析某个元素,会遍历整个XML,识别元素节点名称
- (void)parser:didStartElement:namespaceURI:qualifiedName:attributes:
// 2. 文本节点,得到文本节点里存储的信息数据,对于大数据可能会接收多次!为了节约内存开销
- (void)parser:foundCharacters:
// 3. 结束某个节点,存储从parser:foundCharacters:方法中获取到的信息
- (void)parser:didEndElement:namespaceURI:qualifiedName:
注意:在解析过程中,上述三个方法会不停的重复执行,直到遍历完成为止
// 4. 开始解析XML文档
- (void)parserDidStartDocument:
// 5. 解析XML文档结束
- (void)parserDidEndDocument:
// 6. 解析出错
- (void)parser:parseErrorOccurred:
JSON:
1、介绍:
作为一种轻量级的数据交换格式,正在逐步取代XML,成为网络数据的通用格式
SBJsonJSONKitTouchJson
<2>存储加载到的数据- (IBAction)loadJSONData:(id)sender
{
// 定义URL
NSString *urlStr = [NSString stringWithFormat:@"%@/itcast/videos.php?format=json", WEB_ROOT_URL];
NSURL *url = [NSURL URLWithString:urlStr];
// 获取网络数据
NSData *data = [NSData dataWithContentsOfURL:url];
// 反序列化JSON数据,生成NSArray
NSArray *array = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil];
// 将JSON字典写入文件,便于调试
NSArray *docs = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *docDir = [docs[0]stringByAppendingPathComponent:@"jsonArray.plist"];
[array writeToFile:docDir atomically:YES];
}
// 初始化数据数组
if (_dataList == nil) {
_dataList = [NSMutableArray array];
} else {
[_dataList removeAllObjects];
}
// 填充数组
for (NSDictionary *dict in array) {
Video *video = [[Video alloc]init];
[video setId:[dict[@"id"]integerValue]];
[video setName:dict[@"name"]];
[video setLength:[dict[@"length"]integerValue]];
[video setVideoURL:[NSString stringWithFormat:@"%@%@", WEB_ROOT_URL, dict[@"videoURL"]]];
[video setImageURL:[NSString stringWithFormat:@"%@%@", WEB_ROOT_URL, dict[@"imageURL"]]];
[video setDescription:dict[@"description"]];
[video setTeacher:dict[@"teacher"]];
[_dataList addObject:video];
}
// 刷新表格
[_videosTable reloadData];