【Swift】 GET&POST请求 网络缓存的简单处理
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 磁盘缓存 20M diskPath-》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 }
【Swift】 GET&POST请求 网络缓存的简单处理的更多相关文章
- Android okHttp网络请求之缓存控制Cache-Control
前言: 前面的学习基本上已经可以完成开发需求了,但是在项目中有时会遇到对请求做个缓存,当没网络的时候优先加载本地缓存,基于这个需求我们来学习一直okHttp的Cache-Control. okHttp ...
- Swift使用Alamofire实现网络请求
Alamofire是一个用Swift编写的HTTP网络库,由此前热门开源项目AFNetworking的的作者mattt开发,可非常简单地用于异步网络通信. 要获取最新版本的 Alamofire,前往h ...
- iOS 网络请求数据缓存
1. NSURLCache简介: iOS对NSURLRequest提供了7种缓存策略:(实际上能用的只有4种) NSURLRequestUseProtocolCachePolicy // 默认的缓存策 ...
- 使用Retrofit和Okhttp实现网络缓存。无网读缓存,有网根据过期时间重新请求 (转)
使用Retrofit和Okhttp实现网络缓存,更新于2016.02.02原文链接:http://www.jianshu.com/p/9c3b4ea108a7 本文使用 Retrofit2.0.0-b ...
- Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类
Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类 转载自http://www.trinea.cn/android/android-common-lib/ 介绍总结的一 ...
- Nohttp请求图片的两种简答的方式:普通请求以及缓存请求
开局声明:这是基于nohttp1.0.4-include-source.jar版本写的教程 由于nohttp功能强悍,因此需要多种权限,仅仅一个联网的权限是不够的,如果只给了Internet的权限,去 ...
- Alamofire请求网络
HTTP - GET和POST请求- 如果要传递大量数据,比如文件上传,只能用POST请求- GET的安全性比POST要差些,如果包含机密/敏感信息,建议用POST- 如果仅仅是索取数据(数据查询), ...
- 【Java/Android性能优 7】Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类
本文转自:http://www.trinea.cn/android/android-common-lib/ 介绍总结的一些android公共库,包含缓存(图片缓存.预取缓存.网络缓存).公共View( ...
- Android请求网络共通类——Hi_博客 Android App 开发笔记
今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...
随机推荐
- 编译命令行终端 swift
So, this is where swift lives, after you've installed XCode 6 Beta: /Applications/Xcode6-Beta.app/Co ...
- 同步(Synchronization)
多线程应用程序的存在,在运行打开一个潜在的多线程安全的接入资源. 两个线程相同的资源可能会以意想不到的方式改变相互干扰. 例如.一个线程可以覆盖有一个线程改变或使应用程序进入一个潜在的无效的状态未知. ...
- android关键知识
1.handler 与Looper 与MessageQueue .Message关系 handler:是处理主线程(ui线程)处理耗时操作的线程,通过post message到MessageQueue ...
- 为什么OC语言很难
作为一个Objective-C的coder,我总能听到一部分人在这门语言上抱怨有很多问题.他们总在想快速学习这门语言来写一个App出来,但他们也总是联想到Objective-C看上去实在太难了或者在想 ...
- OpenGL学习日记-2015.3.13——多实例渲染
实例化(instancing)或者多实例渲染(instancd rendering)是一种连续运行多条同样渲染命令的方法.而且每一个命令的所产生的渲染结果都会有轻微的差异. 是一种很有效的.有 ...
- opengl微发展理解
1.什么是OpenGL? 一种程序,可以与界面和图形硬件交互作用.一个开放的标准 2.软件管道 请看上图 - Apllication层 表示你的程序(调用渲染命令.如opengl API) - ...
- 【十三】注入框架RoboGuice采用:(Logging via Ln)
上一篇我们简单的介绍了一下RoboGuice的使用([十二]注入框架RoboGuice使用:(Your First Injected ContentProvider)),今天我们来看下Log日志使用. ...
- Java TCP/UDP网络通信编程
本文转自:http://www.cnblogs.com/cdtarena/archive/2013/04/10/3012282.html 网络应用中基本上都是TCP(Transmission Cont ...
- LAN远程重启server安全方法
原创文章.转载请注明出处.(百度经验:http://jingyan.baidu.com/article/454316abaadc41f7a7c03a13.html) 在局域网中,管理和操作server ...
- WPF学习(7)命令
在上一篇中,我们学习了WPF的路由事件,而在本节将学习一个更为抽象且松耦合的事件版本,即命令.最明显的区别是,事件是与用户动作相关联的,而命令是那些与用户界面想分离的动作,例如我们最熟悉的剪切(Cut ...