iOS网络编程
今天的重点是UIWebView、NSURLSession、JSon。
网络编程联网准备:1、在Info.plist中添加AppTransportSecurity类型Dictionary;2、在AppTransportSecurity下添加AllowArbitaryLoads类型Boolean。
如果仅仅是查询数据,建议使用GET;如果是增删改数据,建议用POST。
使用第三方框架:Alamofire——著名的AFNetworking网络基础库。
UIWebView的使用:
加载显示网页:
class ViewController: UIViewController, UIWebViewDelegate {
override func viewDidLoad() {
super.viewDidLoad()
let webView = UIWebView(frame: UIScreen.main.bounds)
let url = URL(string: "http://www.cnblogs.com/quanxi")
let request = URLRequest(url: url!)
webView.loadRequest(request)
webView.delegate = self
self.view.addSubview(webView)
}
}
整个过程中,有一些方法:
//连接改变时
func webView(_ webView: UIWebView, shouldStartLoadWith request: URLRequest, navigationType: UIWebViewNavigationType) -> Bool {
return true
}
//UIWebView加载完成时调用,而无论链接是否正确
func webViewDidStartLoad(_ webView: UIWebView) {
print("===hello")
}
网络操作
首先给出一个JSON测试的接口地址:http://mapi.damai.cn/proj/HotProj.aspx?CityId=0&source=10099&version=30602。下面是用Jason.app序列化后的结果:

第一种NSURLConnection(为了获得数据,一定要让类遵循NSURLConnectionDataDelegate):
- 首先创建请求对象:var request = NSURLRequest(url: URL(string: "http://www.sina.com")!)。
- 创建网络连接的对象:_ = NSURLConnection(request: req as URLRequest, delegate: self),用这个对象来获得数据。
然后有如下方法可在整个网络请求的过程中调用。
extension ViewController: NSURLConnectionDataDelegate {
//连接网络,连接成功则调用
func connection(_ connection: NSURLConnection, didReceive response: URLResponse) {
let res = response as! HTTPURLResponse
print("===\(res.statusCode)")
}
//连接成功,后服务器请求数据
func connection(_ connection: NSURLConnection, didReceive data: Data) {
print("===\(data)")
downloadData.append(data) //var downloadData = NSMutableData()
}
//http请求结束后,对数据的处理
func connectionDidFinishLoading(_ connection: NSURLConnection) {
//此时downloadData代表了所有的数据
//解析为Json数据
let dict = try! JSONSerialization.jsonObject(with: downloadData as Data, options: .allowFragments) as! NSDictionary
let list = dict["list"] as! NSArray
print("===\(dict)")
for d in list {
var model = Model()
let di = d as! NSDictionary
model.Name = di.object(forKey: "Name") as! String
model.venName = di.object(forKey: "VenName") as! String
model.showTime = di.object(forKey: "ShowTime") as! String
dataSource.add(model)
}
}
}
第二种,现在更推崇使用NSURLSession(就必须使用到NSURLSessionTask):
NSURLSessionTask和其子类的关系:

使用NSURLSession的步骤:
- 获得会话对象Session的实例
- 再通过该实例,创建各种task
- 然后编写好task,就可以执行task了。
而真正的使用,有两种方法:
- 使用URLRequest对象
//
// ViewController.swift
// k
//
// Created by apple on 16/12/30.
// Copyright © 2016年 liuzhenbing. All rights reserved.
// import UIKit class ViewController: UIViewController, UIWebViewDelegate { override func viewDidLoad() {
super.viewDidLoad()
let url = URL(string: "http://mapi.damai.cn/proj/HotProj.aspx?CityId=0&source=10099&version=30602")
let request = URLRequest(url: url!) //获得会话对象Session的实例
let session = URLSession.shared
//再创建各种需要的task
let dataTask = session.dataTask(with: request) {
(data, response, error) in
var dict: NSDictionary? = nil
if error == nil {
do {
dict = try JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.init(rawValue: 0)) as? NSDictionary
} catch {}
//下面就是JSON的具体解析了:可以参照第一种Connection方法
let list = dict?["list"] as! NSArray
for i in list {
let dic = i as! NSDictionary
//下面就是最底层,也就是各个具体的字段值
print("===\(dic.object(forKey: "Name") as! String)")
}
}
}
dataTask.resume() //执行任务:最关键的一步,一定要记住
}
} - 直接使用URL对象:
//
// ViewController.swift
// k
//
// Created by apple on 16/12/30.
// Copyright © 2016年 liuzhenbing. All rights reserved.
// import UIKit class ViewController: UIViewController, UIWebViewDelegate { override func viewDidLoad() {
super.viewDidLoad()
let url = URL(string: "http://mapi.damai.cn/proj/HotProj.aspx?CityId=0&source=10099&version=30602")
let session = URLSession.shared
let dataTask = session.dataTask(with: url!) {
(data, response, error) in
var dict: NSDictionary? = nil
if error == nil {
do {
dict = try JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.init(rawValue: 0)) as? NSDictionary
} catch {}
let list = dict?["list"] as! NSArray
for i in list {
let dic = i as! NSDictionary
print("===\(dic.object(forKey: "Name") as! String)")
}
}
}
dataTask.resume()
}
}
以上代码都是简单GET示例,下面给出POST的用法:
//let url = URL(string: "http://www.crs811.com/Json/login.php")!,而且POST必须用request的任务
request.httpMethod = "POST"
request.httpBody = "username=crs811&pwd=123456".data(using: .utf8)
网络编程的下载主题:

用swift的URLSession来下图片:
class ViewController: UIViewController, URLSessionDownloadDelegate {
override func viewDidLoad() {
super.viewDidLoad()
let url = URL(string: "http://images2015.cnblogs.com/blog/1032080/201612/1032080-20161206214110210-418912424.jpg")!
//session一定要这样设置,因为要更改下载的代理
let session = URLSession(configuration: .default, delegate: self, delegateQueue: nil)
let downLoadTask = session.downloadTask(with: url)
downLoadTask.resume()
//以上代码就已经把想要的文件,下下来了,但是现在,还有两个问题:要找到文件;这个文件还不能用,因为是.tmp的,要另存为,如.jpg
}
func urlSession(_ session: URLSession, downloadTask: URLSessionDownloadTask, didFinishDownloadingTo location: URL) {
let source = location.path
let save = NSHomeDirectory().appending("/test.jpg")
print("===\(save)")
let fileManager = FileManager.default
do {
if fileManager.fileExists(atPath: save) { //如果文件存在,不删除的话,继续保存在这里,是会失败的
try fileManager.removeItem(atPath: save)
}
try fileManager.moveItem(atPath: source, toPath: save)
} catch {}
}
}
用SDWebImage库异步加载一张图片(是UIImageView调用该方法,而不是UIImage):
首先引入库的时候有几个选项,记住一定不要选引用,还要记住设置联网。
@IBOutlet weak var img: UIImageView!
override func viewDidLoad() {
super.viewDidLoad()
img?.sd_setImage(with: URL(string: "http://www.crs811.com/wp-content/uploads/2016/11/test.jpg"))
}
如果使用cocoaPods来管理库,也要搭建OC桥才能使用(不知道是不是该库是OC的缘故)。一个简单的例程:http://download.csdn.net/detail/leaf_and_wind/9724825
iOS网络编程的更多相关文章
- iOS网络编程模型
iOS网络编程层次结构也分为三层: Cocoa层:NSURL,Bonjour,Game Kit,WebKit Core Foundation层:基于 C 的 CFNetwork 和 CFNetServ ...
- IOS网络编程——第三方类库
IOS网络编程——第三方类库 目录 概述 ASIHttpRequest AFNetworking 其他 概述 ASIHttpRequest AFNetworking 其他
- IOS网络编程:HTTP
IOS网络编程:HTTP HTTP定义了一种在服务器和客户端之间传递数据的途径. URL定义了一种唯一标示资源在网络中位置的途径. REQUESTS 和 RESPONSES: 客户端先建立一个TCP连 ...
- iOS网络编程笔记——Socket编程
一.什么是Socket通信: Socket是网络上的两个程序,通过一个双向的通信连接,实现数据的交换.这个双向连路的一端称为socket.socket通常用来实现客户方和服务方的连接.socket是T ...
- 浅谈iOS网络编程之一入门
计算机网络,基本上可以抽象是端的通信.实际在通讯中会用到不同的设备,不同的硬件中,为了能友好的传输信息,那么建立一套规范就十分必要了.先来了解一些基本概念 了解网络中传输的都是二进制数据流. 2.了 ...
- iOS 网络编程:socket
@import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...
- iOS 网络编程模式总结
IOS 可以采用三类api 接口进行网络编程,根据抽象层次从低到高分别为socket方式.stream方式.url 方式. 一 .socket 方式 IOS 提供的socket 方式的网络编程接口为C ...
- ios网络编程(入门级别)-- 基础知识
在学习ios的过程中,停留在UI控件很长时间,现在正在逐步的接触当中!!!!!!在这个过程中,小编学到了一些关于网络编程知识,并且有感而发,在此分享一下: 关于网络请求的重要性我想不用多说了吧!!!对 ...
- iOS 网络编程(HTTP协议)
HTTP协议的概念HTTP协议,Hyper Text Transfer Protocol (超文本传输协议)是用于从万维网服务器传送超文本到本地浏览器的传输协议,HTTP是一个应用层协议,由请求和响应 ...
- 从socket开始讲IOS网络编程
home list tags talk user rss Mac&iOS Socket 大纲 一.Socket简介 二.BSD Socket编程准备 1.地址 2.端口 3.网络字节序 4.半 ...
随机推荐
- MUI开发APP,scroll组件,运用到区域滚动
最近在开发APP的过程中,遇到一个问题,就是内容有一个固定的头部和底部. 头部就是我们常用的header了,底部的话,就放置一个button,用来提交页面数据或者进入下一个页面等,效果 ...
- linq to entity常用操作
一.聚合函数查询 ; using (xxxEntities db = new xxxEntities()) { sum = db.userinfo.AsNoTracking().Where(d =&g ...
- CSS3与页面布局学习总结(八)——浏览器兼容与前端性能优化
一.浏览器兼容 1.1.概要 世界上没有任何一个浏览器是一样的,同样的代码在不一样的浏览器上运行就存在兼容性问题.不同浏览器其内核亦不尽相同,相同内核的版本不同,相同版本的内核浏览器品牌不一样,各种运 ...
- 如何写复杂的SQL
经常有人问我那非常复杂的sql是怎么写出来的,我一直不知道该怎么回答. 因为虽然我写这样的sql很顺手,可是我却不知道怎么告诉别人怎么写. 很多人将这个问题归结为天赋,我却不这么看,我 ...
- 移动端自适应之——rem与font-size
需求:在不同的移动终端设备中实现,UI设计稿的等比例适配. 方案:布局排版都用rem做单位,然后不同宽度的屏,js动态计算根节点的font-size. 假设设计稿是宽750px来做的,书写css方便计 ...
- 【目录】JVM目录
JVM学习目录 为了方便园友,现对JVM序列笔记做了归档,园友们可以一口气读完整个JVM的笔记 1. [JVM]JVM系列之JVM体系(一) 2. [JVM]JVM系列之垃圾回收(二) 3. [JVM ...
- TCP四种计时器
TCP共使用以下四种计时器,即重传计时器.坚持计时器.保活计时器和时间等待计时器 .这几个计时器的主要特点如下: 1.重传计时器 当TCP发送报文段时,就创建该特定报文段的重传计时 ...
- DDD及相关概念
领域:指一个具体的应用范围,比如电商.订票管理.会议管理等,实现某一领域的功能,与其对应的商业领域一致.譬如Contoso会议管理系统从两个方面来阐述(1)系统概览:销售会议座位.创建新会议[领域的活 ...
- Wizard Framework:一个自己开发的基于Windows Forms的向导开发框架
最近因项目需要,我自己设计开发了一个基于Windows Forms的向导开发框架,目前我已经将其开源,并发布了一个NuGet安装包.比较囧的一件事是,当我发布了NuGet安装包以后,发现原来已经有一个 ...
- 利用Python进行数据分析(1) 简单介绍
一.处理数据的基本内容 数据分析 是指对数据进行控制.处理.整理.分析的过程. 在这里,“数据”是指结构化的数据,例如:记录.多维数组.Excel 里的数据.关系型数据库中的数据.数据表等. 二.说说 ...