络上传输数据通用的有XML,JSON等,iOS中也可以用Plist。
三、XML解析
四、JSON解析
解析代码如下:
要进行数据传输,就要首先进行序列化:
1.
序列化
.
对象转换成二进制流
.(
这个一句话就行
)
2
.
反序列化
.
二进制流转换为对象
等
. (
关键要弄清楚这个
)
JSON
:
(
和
XML
一样都是用来传数据的
)
轻量级的数据交换格式
,
正在逐步取代
XML.
XML
:
结构性的标记语言
,
易读
.
但数据量大
.
Plist
偶尔用着玩玩:
Mac、iOS中用的多一种格式。
一、应用场景
1、
XML
的应用场景
:
XMPP——
即时通讯,
KissXML
RSS
目前还有少量的企业在使用
开源的
WebServices
,例如天气预报等
如果设计好
XML
的接口,
XML
的解析并不会太复杂
2、
JSON
的应用场景
:
(
数据量小
,
轻量级
)
移动开发中绝大多数还是使用
JSON
如果自己开发,或者公司后台接口,最好使用
JSON.
二、Plist解析数据
定义一个Plist的格式如下:
解析代码如下:(在异步线程中进行, 最后得到array)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
- (
void
)loadData
{
// 1. url
NSURL *url = [NSURL URLWithString:@
"http://localhost/videos.plist"
];
// 2. request
// timeoutInterval 如果5.0之内没有从服务器返回结果,就认为超时了
/**
NSURLRequestUseProtocolCachePolicy = 0, // 使用协议缓存策略(默认)
NSURLRequestReloadIgnoringLocalCacheData = 1, // 忽略本地缓存数据(断点续传时使用)
NSURLRequestReloadIgnoringCacheData = NSURLRequestReloadIgnoringLocalCacheData, == 1
// 以下少用
NSURLRequestReturnCacheDataElseLoad = 2, // 如果有缓存,就返回缓存数据,否则加载
NSURLRequestReturnCacheDataDontLoad = 3, // 死活不加载远程服务器数据,如果用户没有网络连接时可以使用
// 以下没有实现
NSURLRequestReloadIgnoringLocalAndRemoteCacheData = 4, // 没有实现
NSURLRequestReloadRevalidatingCacheData = 5, // 没有实现
*/
NSURLRequest *request = [NSURLRequest requestWithURL:url cachePolicy:0 timeoutInterval:5.0];
// 3. 网络异步请求
[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
if
(connectionError) {
NSLog(@
"错误 %@"
, connectionError);
return
;
}
// data是一个plist数据, 对data进行反序列化,解析
NSArray *array = [NSPropertyListSerialization propertyListWithData:data options:0 format:NULL error:NULL];
// 刷新数据,在UI线程中更新UI
dispatch_async(dispatch_get_main_queue(), ^{
//.....
});
}];
}
|
三、XML解析
iOS中XML
解析方式的两种方式(Android中好友pull等)
:
1、
SAX
(
SimpleAPI for XML
)
只能读,不能修改
,只能顺序访问,适合解析大型
XML
,
解析速度快
常应用于处理大量数据的
XML
,实现异构系统的数据访问,实现跨平台
从文档的开始通过每一节点移动,定位一个特定的节点
2、
DOM
(
DocumentObject
Model
)
不仅能读,还能修改
,而且能够实现随机访问,缺点是
解析速度慢
,适合解析小型文档
.
方便操作
.
在内存中生成节点树操作
代价昂贵
XML
解析步骤
:
1、
实例化
NSXMLParser
,
传入
从服务器接收的
XML
数据
2、
定义解析器
代理
3、
解析器
解析,
通过解析代理方法完成
XML
数据的解析。
解析
XML
用到的的
代理方法
:
1. 开始解析XML文档
- (void)parserDidStartDocument:
2. 开始解析某个元素,会遍历整个XML,识别元素节点名称,如<video>开头
-(void)parser:didStartElement:namespaceURI:qualifiedName:attributes:
3. 文本节点,得到文本节点里存储的信息数据。 节点中的数据<video>XXXX</video>
- (void)parser:foundCharacters:
4. 结束某个节点 如</video>开头
- (void)parser:didEndElement:namespaceURI:qualifiedName:
注意:在解析过程中,2、3、4三个方法会不停的重复执行,直到遍历完成为止
5.解析XML文档结束
- (void)parserDidEndDocument:
6.解析出错
-(
void)parser:parseErrorOccurred:
注意: 从
网络上加装数据是
不能用懒加载的.
XML文件格式如下:
<?xml version="1.0" encoding="utf-8"?> <videos> <video videoId="1"> <name>苍老师1</name> <length>320</length> <videoURL>/苍老师1.mp4</videoURL> <imageURL>/苍老师1.png</imageURL> <desc>学iOS找苍老师1</desc> <teacher>苍老师111</teacher> </video> <video videoId="2"> <name>苍老师2</name> <length>2708</length> <videoURL>/苍老师2.mp4</videoURL> <imageURL>/苍老师2.png</imageURL> <desc>学iOS找苍老师2</desc> <teacher>苍老师222</teacher> </video> </videos>解析代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
/** 加载数据 */
- (
void
)loadData
{
// 1. url确定资源
NSURL *url = [NSURL URLWithString:@
"http://localhost/videos.xml"
];
// 2. request建立请求
NSURLRequest *request = [NSURLRequest requestWithURL:url];
// 3. 发送异步请求,新建数据处理队列,待数据处理完成后,再更新UI
[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
// 1> 实例化XML解析器
NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data];
// 2> 设置解析器的代理
parser.delegate = self;
// 3> 开始解析
[parser parse];
}];
}
#pragma mark - XML解析代理方法
// 1. 开始解析文档
- (
void
)parserDidStartDocument:(NSXMLParser *)parser
{
// 为了避免重复刷新数据,可以清空数组
[self.videoList removeAllObjects];
}
// 2,3,4三个方法会循环被调用
// 2. 开始一个元素(节点)<xxx>
- (
void
)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
if
([elementName isEqualToString:@
"video"
]) {
// 创建新的video对象
self.currentVideo = [[Video alloc] init];
// 使用KVC赋值
[self.currentVideo setValue:attributeDict[@
"videoId"
] forKeyPath:@
"videoId"
];
}
// 在开始第3个方法前,清空字符串内容
[self.elementM setString:@
""
];
}
// 3. 发现字符(节点中间内容)
- (
void
)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
[self.elementM appendString:string];
}
// 4. 结束节点</xxx>
- (
void
)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
{
if
([elementName isEqualToString:@
"video"
]) {
// 将当前正在解析的节点添加到数组
[self.videoList addObject:self.currentVideo];
}
else
if
(![elementName isEqualToString:@
"videos"
]) {
[self.currentVideo setValue:self.elementM forKeyPath:elementName];
}
}
// 5. 结束文档解析
- (
void
)parserDidEndDocument:(NSXMLParser *)parser
{
NSLog(@
"结束文档解析 %@"
, self.videoList);
NSLog(@
"%@"
, [NSThread currentThread]);
dispatch_async(dispatch_get_main_queue(), ^{
//UI线程中刷新UI......
});
}
// 6. 在处理网络数据时,千万不要忘记出错处理
- (
void
)parser:(NSXMLParser *)parser parseErrorOccurred:(NSError *)parseError
{
NSLog(@
"错误 %@"
, parseError);
}
|
四、JSON解析
解析出来的数据需要进行反序列化,方法如下:
[NSJSONSerialization
JSONObjectWithData:data options:0 error:NULL];
JSON解析方便、且轻量级,特别对于手机端,节省流量,快。
JSON格式数据如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
[
{
"videoId"
:
"1"
,
"name"
:
"苍老师1"
,
"length"
:
"320"
,
"videoURL"
:
"\/苍老师1.mp4"
,
"imageURL"
:
"\/苍老师1.png"
,
"desc"
:
"学iOS找苍老师1"
,
"teacher"
:
"苍老师111"
},
{
"videoId"
:
"2"
,
"name"
:
"苍老师2"
,
"length"
:
"2708"
,
"videoURL"
:
"\/苍老师2.mp4"
,
"imageURL"
:
"\/苍老师2.png"
,
"desc"
:
"学iOS找苍老师2"
,
"teacher"
:
"苍老师222"
}
]
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
- (
void
)loadData
{
// 1. url
NSURL *url = [NSURL URLWithString:@
"http://localhost/videos.json"
];
// 2. request
NSURLRequest *request = [NSURLRequest requestWithURL:url];
// 3. 发送异步请求
[NSURLConnection sendAsynchronousRequest:request queue:[[NSOperationQueue alloc] init] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
// data是一个json数据
// 对data进行反序列化,解析
NSArray *array = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];
// 刷新数据,更新UI
dispatch_async(dispatch_get_main_queue(), ^{
//在主线程中更新UI......
});
}];
}
|