向服务器获取数据就用GET,上传数据就用POST(用POST有请求体,GET没有)
-
允许使用不安全的http强制加载,改为yes
在info.plist文件中点击information Propert List 右边的加号输入App 会提示一个App Transport Security... 的东西,然后点开再添加如图上这个Allow,将右边的Value该为Yes就可以加载不安全的http
Hack: 隐藏没有数据的单元格的分割线
tableView.tableFooterView = UIView()
图片大小不匹配,会自动伸缩成合适大小,不会变形(枚举,可以直接点出来)
photoImageView.contentMode = .ScaleAspectFit
通过网络接口获取需要使用的数据
创建请求对象
url后面字符串中newtop后面的问号称为查询字符串其中&符号隔开了两个查询参数
num表示一次获取多少条数据,page表示访问第几页的数据(这里的num是服务器中说明必须实现的参数)
let url = NSURL(string: "http://apis.baidu.com/txapi/huabian/newtop?num=10&page=\1")
let request = NSMutableURLRequest(URL: url!)
// 在请求头中添加apikey(如果没有apikey无法请求数据)
request.addValue("56fd25774f88013dcbddc9e350f442cc", forHTTPHeaderField: "apikey")
创建默认配置的会话
let session = NSURLSession.sharedSession()
有了会话就可以创建三种不同类型的任务:
- 1. NSURLSessionDataTask - 从服务器获取数据的任务
- 2. NSURLSessionUploadTask - 上传任务
- 3. NSURLSessionDownloadTask - 下载任务
// (request)请求体 (response)反应体
let dataTask = session.dataTaskWithRequest(request) { (data, response, error) -> Void in
// 如果等于空就拿到数据 (等于空就是表示没有异常,获取到数据)
if error == nil {
// 服务器给的数据方括号打头就是数组、花括号打头的就是字典
// 通过NSJSONSerialization类将NSData解成字典(将JSON类型的数据转成数组或者是字典)
let dict = try! NSJSONSerialization.JSONObjectWithData(data!, options: .MutableContainers) as! [String: AnyObject]
// 从字典中取出名为newslist的键对应的数组
if let array = dict["newslist"] as? [[String: String]] {
// 如果执行下啦刷新操作就删除数组中原来的数据模型
if self.isRefreshing {
self.dataArray.removeAll()
}
// 数组中的元素又是一个字典正好对应一个模型对象
for objDict in array {
// 每循环一次就创建一个模型对象
let model = NewModel()
// 直接用字典对象给模型的所有属性赋上对应的值
// KVC - Key Value Coding (键值对编码)
// 字典中的键对应对象的属性 字典中键所对应的值就是对象的属性值
// KVC不是Swift中的内容,所以如果要使用KVC 类需要继承NSObject
model.setValuesForKeysWithDictionary(objDict)
self.dataArray.append(model)
}
}
else {
print("从服务器获取数据失败")
}
}
// 恢复执行任务(调用resume方法.任务就会执行)
// resume方法是一个异步执行的方法 所谓的异步就是没有阻塞当前的主线程
// 而是在一个新的线程(并发线程)中去执行的
dataTask.resume()
}
}
由于解析数据的代码并没有在主线程中执行,因此在刷新表格视图前
应该让刷新表格视图的代码重新回到主线程中执行
因为苹果要求刷新UI的代码必须在主线程中完成
dispatch_async(dispatch_get_main_queue(), {
})
并发线程
dispatch_async(dispatch_get_global_queue(0, 0)) {
}
上面中如果想要使用KVC大招 就必须在声明的继承的NSObject类中实现一个方法
if let url = NSURL(string: model.picUrl) {
// 将耗时间的获取图片数据的操作放到并发线程中执行
dispatch_async(dispatch_get_global_queue(0, 0)) {
let imageData = NSData(contentsOfURL: url)
// 获得数据以后回到主线程刷新UIImageView
dispatch_async(dispatch_get_main_queue(), {
cell.photoImageView.image = imageData != nil ? UIImage(data: imageData!) : UIImage(named: "vip")
})
}
}