【Swift】 GETPOST请求 网络缓存的简单处理

news/2024/7/7 20:24:14

GET & POST 的对比

源码: https://github.com/SpongeBob-GitHub/Get-Post.git

1. URL

- GET

所有的参数都包含在 URL 中

1. 如果需要添加参数,脚本后面使用 `?`

2. 参数格式:值对

参数名=值

3. 如果有多个参数,使用 `&` 连接

4. 在 get 方法中,url字符串中不能包含中文或者特殊符号 空格

如果出现,需要添加百分号转义

- POST

URL中不包含参数,直接指定登录脚本即可

2. Request

- GET

- 因为 GET 的效率高,而且性能好,能够被缓存,使用频率高

- 是默认的请求方法,不需要任何设定

- POST

- 需要指定请求方法

request.HTTPMethod = @"POST";

- 所有参数都包含在请求体中,二进制数据,来源:firebug的源代码中粘贴

- 参数格式,和 GET 的几乎一致,只是没有 `?`

- POST方法获得的网络数据不能被缓存

3. Connection

这是一个最单纯的网络方法,只是发送"请求",接收服务器返回的二进制"实体数据"

GET & POST 没有任何区别

GET:

/// GET 登录
func getLogin() {
  let username = "SpongeBob"
  let pwd = "1234567890"
  /**
  GET 方法中,所有的参数都包含在 URL 中
  提示:login.php 是测试用的脚本
  【需要:在Mac电脑上,配置Apache服务器--http://www.cnblogs.com/SpongeBob-GitHub/p/4496164.html & 将login.php脚本放到服务器上!】
  注意:得先启动配置好的Apache服务器
    $ sudo apachectl -k restart
  1. 如果需要添加参数,使用 ?
  2. 参数格式:值对
  参数名=值
  3. 如果有多个参数,使用 & 连接
  4. 在 get 方法中,url字符串中不能包含中文或者特殊符号 空格
  如果出现,需要添加[百分号]转义
  */
  var urlString = NSString(format: "http://127.0.0.1/login.php?username=\(username)&password=\(pwd)")
  // 利用UTF8编码
  urlString = urlString.stringByAddingPercentEscapesUsingEncoding(NSUTF8StringEncoding)!
  let url = NSURL(string: urlString as String)
  // 因为 GET 的效率高,而且性能好,因此在网络访问中,使用频率非常高!默认的请求方法就是 GET 的,无需指定!
  // GET 方法是可以缓存的!
  var request = NSURLRequest(URL: url!, cachePolicy: NSURLRequestCachePolicy.ReturnCacheDataElseLoad, timeoutInterval: 10.0)
  println(request.HTTPMethod)
  NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue.mainQueue()) { (response, data, connectionError) -> Void in
    println(response)
    if connectionError != nil {
      println("login error....\(connectionError)")
    } else {
      // 这里的data数据,就是通过GET请求获取到的,第一次获取成功后,就缓存到本地沙盒中,下次就不再获取,直接从本地加载!!!--缓存
      // 问题:但是如果这时候,服务器中返回的数据修改了,这里依然会打印修改前的data!
      // 比如:将login.php脚本中得返回userName改成 xxxx,依然会打印为SpongeBob。
      // FIXME: 这种问题一般会出现在图片的获取,我们重新写一个类来解决这个问题!
      var dict = NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingOptions.MutableContainers, error: nil) as! NSDictionary
      println("GET: -> \(dict)")
    }
  }
}

POST:

/// POST 登录
func postLogin() {
  let username = "SpongeBob"
  let pwd = "1234567890"
  let url = NSURL(string: "http://localhost/login.php")
  var request = NSMutableURLRequest(URL: url!, cachePolicy: NSURLRequestCachePolicy.ReturnCacheDataElseLoad, timeoutInterval: 10.0)
  request.HTTPMethod = "POST"
  println(request.HTTPMethod)
  // 设置请求体为二进制数据
  var bodyStr = NSString(format: "username=\(username)&password=\(pwd)")
  request.HTTPBody = bodyStr.dataUsingEncoding(NSUTF8StringEncoding)
  NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue.mainQueue()) { (response, data, connectionError) -> Void in
    println(response)
    if connectionError != nil {
      println("login error....\(connectionError)")
    } else {
      var dict = NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingOptions.MutableContainers, error: nil) as! NSDictionary
      println("POST: -> \(dict)")
    }
  }
}

针对于GET请求缓存----》 

这里的data数据,就是通过GET请求获取到的,第一次获取成功后,就缓存到本地沙盒中,下次就不再获取,直接从本地加载!!!--缓存

问题:但是如果这时候,服务器中返回的数据修改了,这里依然会打印修改前的data!

比如:将login.php脚本中得返回userName改成 xxxx,依然会打印为SpongeBob。

FIXME: 这种问题一般会出现在图片的获取,我们重新写一个类来解决这个问题!

/// GET 加载网络图片 -- 缓存
func loadImageWithGET() {
  let url = NSURL(string: "http://localhost/images/1.png")
  var request = NSMutableURLRequest(URL: url!, cachePolicy: NSURLRequestCachePolicy.ReloadIgnoringLocalAndRemoteCacheData, timeoutInterval: 10.0)
  // 设置请求头 - 利用“If-None-Match”判断是否改变
  request.setValue(self.etag, forHTTPHeaderField: "If-None-Match")
  println(request.HTTPMethod)
  NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue.mainQueue()) { (response, data, connectionError) -> Void in
    var httpRespone = response as! NSHTTPURLResponse
    println("\(httpRespone.allHeaderFields) + \(httpRespone)")
    // 第2次点击时,为304,即需要从本地加载
    if httpRespone.statusCode == 304 {
      println("Loading the local data...")
      // NSURLCache
      var cacheResponse = NSURLCache.sharedURLCache().cachedResponseForRequest(request)
      self.imgView.image = UIImage(data: cacheResponse!.data)
      return
    }
    self.etag = httpRespone.allHeaderFields["Etag"] as? String
    self.imgView.image = UIImage(data: data)
  }
}

网络缓存的处理

/**

* [iOS] 简述 NSURLCache 的存储目录

**

(lldb) po NSHomeDirectory()

"/Users/xxxx/Library/Developer/CoreSimulator/Devices/5A46B8A4-xxxx-4B6A-B5B8-F76A6E13998F/data/Containers/Data/Application/EFEF0D66-xxxx-4EE6-B569-F94429362922"

**

使用AFNetworking 、 SDWebImage 等等开源库做网络数据缓存的时候要注意可能会出现重复缓存(因为NSURLCache已经做了一次缓存,存在Disk中 !

1. 使用 NSURLConnect,、UIWebView 。。 的都会使用导 NSURLCache 的缓存

2. 当使用 NSURL 相关的框架,使用到缓存的时候,系统会在 Caches目录下创建一个 跟 bundle identifer 同名的一个文件夹,以及里面的 Cache.db、Cache.db-shm、Cache.db-wal

三个文件和文件夹 fsCacheData/

·fsCacheData/ 文件夹会在有需要缓存数据到文件的数据才会有,如缓存图片

3. 可以使用 [[NSURLCache sharedURLCache]removeAllCachedResponses] 清理这里所有的缓存数据。

*/

在AppDelegate.swift中添加

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {/*** 设置网络缓存**内存缓存 4M磁盘缓存 20MdiskPath-》nil,会缓存到 cached 的 bundleId 目录下SDWebImage 的缓存1. 缓存时间--1周2. 处理缓存文件,监听系统退出到后台的事件- 遍历缓存文件夹,删除所有过期的文件- 继续遍历缓存文件夹,将最大的文件删除,一直删除到缓存文件的大小和指定的“磁盘限额”一致*/let cache = NSURLCache(memoryCapacity: 4 * 1024 * 1024, diskCapacity: 20 * 1024 * 1024, diskPath: nil)NSURLCache .setSharedURLCache(cache)return true
}
 
推荐文章
  • 1. 消除引入第三方 Framework 导致的 Warning
  • 2. UIScrollview制作图片轮播器
  • 3. iOS网络层架构设计分享
  • 4. IOS autoLayout高级01
  • 5. 上古时代 Objective-C 中哈希表的实现
  • 6. 让你的微信不再被人撤回消息

http://lihuaxi.xjx100.cn/news/235554.html

相关文章

CF1148F - Foo Fighters

CF1148F - Foo Fighters 题意:你有n个物品,每个都有val和mask。 你要选择一个数s,如果一个物品的mask & s含有奇数个1,就把val变成-val。 求一个s使得val总和变号。 解:分步来做。发现那个奇数个1可以变成&#x…

iOS中几种定时器

一、NSTimer 1. 创建方法 NSTimer *timer [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:selector(action:) userInfo:nil repeats:NO];TimerInterval : 执行之前等待的时间。比如设置成1.0,就代表1秒后执行方法target : 需要执行方法的对象…

Ubuntu 上创建常用磁盘阵列

RAID(Redundant Array of Independent Disk 独立冗余磁盘阵列)技术是加州大学伯克利分校1987年提出,最初是为了组合小的廉价磁盘来代替大的昂贵磁盘,同时希望磁盘失效时不会使对数据的访问受损 失而开发出一定水平的数据保护技术。RAID就是一种由多块廉价…

活体检测-用照片来做人脸识别可行吗?

随着科技的迅速发展,智能化也越来越发达,并慢慢进入到我们日常生活中来了。如考勤 早期是人工记录,签到,然后是打卡,刷卡,再到指纹。现在已经发展到更加先进的人脸识别考勤了。 卡可以代打,代刷…

ios关于用xib创建的cell 自动返回cell的高度问题!

1 设置tableView的属性 self.tableView.rowHeight UITableViewAutomaticDimension; self.tableView.estimatedRowHeight 44.0; // 设置为一个接近“平均”行高的值 2 cell要约束好,要能够让cell知道自己的高度根据哪个控件计算就可以(不明白看下图&…

世界最大规模3D打印混凝土步行桥在上海 落成启用

1月12日,世界最大规模3D打印混凝土步行桥在沪落成启用,人们站在桥体上欢庆该新兴建筑体的诞生。 中新网上海1月13日电 (记者 于俊)一座体态优雅、形似飘带的水泥桥12日横跨于上海宝山智慧湾的小河之上,宣告全球最大规模混凝土3D打印步行桥落成…

运维监控基础

一、运维监控基础1.报告网路/系统/业务运行状况2.提前发现被监控设备的问题 二、监控的资源类别硬件监控:CPU、内存、磁盘I/O系统监控:存活状态、进程数、用户数、磁盘使用率网络监控:故障点监测、出站流量、入站流量应用监控:Web…

Swift 3.0 预告:将 Objc 库转换成更符合 Swift 语法风格的形式

转自:swiftcafe Swift 3.0 更新越来越临近,这次更新会给我们带来很多实用的内容,比如对 Objc 库的迁移,会更符合 Swift 的语法风格。用过之前版本的 Swift,我们会发现很多 Objc 库的方法名称其实还是以 Objc 的风格来命…