网络编程基础
我们今天接触网络,首先教你怎么搭建服务器和学习一些vim的命令
可以参考这个链接
服务器的响应
NSURLResponse:
URL重定向:(URL redirection,或称网址重定向或网域名称转址),是指当使用者浏览某个网址时,将他导向到另一个网址的技术。常用在把一串很长的网站网址,转成较短的网址。因为当要传播某网站的网址时,常常因为网址太长,不好记忆;又有可能因为换了网路的免费网页空间,网址又必须要变更,不知情的使用者还以为网站关闭了。这时就可以用网路上的转址服务了。这个技术使一个网页是可借由不同的统一资源定位符(URL)连结。
1.request
- URL 响应的 URL,有的时候,访问一个 URL 地址,服务器可能会出现重定向,会定位到新的地址!
- MIMEType(Content-Type) 服务器告诉客户端,可以用什么软件打开二进制数据!
- expectedContentLength 预期的内容长度,要下载的文件长度
- suggestedFilename "建议"的文件名,方便用户直接保存,很多时候,用户并不关心要保存成什么名字!
- textEncodingName 文本的编码名称 @"UTF8",大多数都是 UTF8
- statusCode 状态码,在做下载操作的时候,需要判断一下 404
- allHeaderFields 所有的响应头字典
2.NSDate 服务器返回的实体内容
3.connectionError 连接错误,在商业软件中,所有的网络操作,都必须处理错误!
[NSURLConnection sendAsynchronousRequest:request queue:[NSOperationQueue
mainQueue] completionHandler:^(NSURLResponse *response, NSData
*data, NSError *connectionError) {
// 提示:千万不要给用户详细的错误信息!
// 有的时候,服务器访问正常,但是会没有数据!
// 以下的 if 是比较标准的错误 处理代码!
if(connectionError != nil || data == nil) {
NSLog(@"网络不给力哦");
return;
}
NSLog(@"%@", response);
NSLog(@"%@", [[NSString alloc] initWithData:data
encoding:NSUTF8StringEncoding]);
}];
是同步的,默认超时时长也是 60s
NSData *data = [NSData dataWithContentsOfURL:url];
UIImage *image = [UIImage imageWithData:data];
网络访问都是耗时的,需要异步处理
NSURLRequest *request = [NSURLRequest requestWithURL:url cachePolicy:0 timeoutInterval:15.0];
参数
- url
- 缓存策略
NSURLRequestUseProtocolCachePolicy = 0,// 默认的缓存策略,使用协议的缓存策略
NSURLRequestReload(加载)Ignoring(忽略)LocalCacheData = 1, 对实时性要求高的
// 忽略本地缓存数据,每次都
从服务器上加载:应用场景:股票,彩票,新闻,天气做"离线"开发时使用,可以先判断当前联网状态,然后设置选项!一般都是把用户拉倒网络上边
NSURLRequestReturnCacheDataElseLoad = 2, 如果有缓存,返回缓存,否则加载
NSURLRequestReturnCacheDataDontLoad = 3, 如果有缓存,返回缓存,佛泽不加载
提示:在实际开发中,不建议使用以下两个选项!
在开发商业应用时,应该把用户拉到网络上来!
广告后面有一套完善的计费系统,展现率,点击率,转换率...
- NSURLRequestReturnCacheDataElseLoad = 2, // 如果有缓存,返回缓存,否则加载
- NSURLRequestReturnCacheDataDontLoad = 3, // 如果有缓存,返回缓存,否则不加载
JSON解析
1.苹果提供了一个 JSON 根 Foundation 转换的类 NSJSONSerialization
我们介绍一下序列化和反序列化
序列化:将OC中的对象(数组/字典)发送给服务器之前,转换成二进制数据的过程
反序列化:获得服务器返回的二进制数据后,转换成 OC 对象(数组/字典)的过程,便于后续的字典转模型
我们对里边的参数进行解析;
选项:
NSJSONReadingMutableContainers = (1UL << 0), 容器可变
NSJSONReadingMutableLeaves = (1UL << 1), 叶子可变,字符串的会使用 NSMutableString
-
NSJSONReadingAllowFragments(片段,碎片) = (1UL << 2) 允许根节点不是数组或者字典,极少见
id json = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];
JSONKit的解析
id result = [[JSONDecoder decoder] objectWithData:data];
结论:我们上述的解析进行比较发现苹果的JSON解析比JSONKit框架的效率要高和占用内存要小,建议使用第三方框架的时候应该把他给隔离开来,方便我们以后替换的方便,或者防止像asi一样不更新了,而且我们发现JSONKit是 MRC和ARC混编的,需要把一些文件设置成ARC的
Plist解析
1.二进制数据
-
2.选项
NSPropertyListImmutable = 0, 不可变
NSPropertyListMutableContainers = 1 << 0, 容器可变
NSPropertyListMutableContainersAndLeaves = 1 << 1 容器和叶子可变
id result = [NSPropertyListSerialization propertyListWithData:data options:0 format:NULL error:NULL];
XML解析
链接:XML解析
首先先插入一个代码块的小技巧
资源库~~Developer~~Xcode~~UserData~~放入我们平时用的代码块
XML,SAX解析
我们在连接的时候,设置一个XML解析器,
NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data]
parser.delegate = self
//解析器开始解析,后续的操作都是通过代理来实现的
1. 打开文档-准备开始解析
- (void)parserDidStartDocument:(NSXMLParser *)parser {
NSLog(@"1. 打开文档");
// 清空数据数组
[self.videos removeAllObjects];
}
2. 开始节点 - 如果是 video 节点,会有属性字典
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict {
}
3. 发现节点中的文字 - 可能会执行多次(需要把几次执行获得的字符串进行拼接)
- (void)parser:(NSXMLParser *)parser foundCharacters:
(NSString *)string {
}
4. 结束节点
- (void)parser:(NSXMLParser *)parser didEndElement:
(NSString *)elementName namespaceURI:(NSString
*)namespaceURI qualifiedName:(NSString *)qName {
}
}
5. 结束文档
- (void)parserDidEndDocument:(NSXMLParser *)parser {
}
总结:我打印了一下这个当前的线程发现也是一个异步执行的线程,上述我们学到了url的重定向,和序列化反序列化,request的参数,表示的不同的含义,缓存测略,JSON,Plist,XML的解析,关于XML的sax解析我们分五个步骤 开始文档--->开始节点---->发现节点中的文字----->结束节点------->结束文字,希望大家共同学习如果有错误的地方希望大家指出来