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请求 网络缓存的简单处理的更多相关文章

  1. Android okHttp网络请求之缓存控制Cache-Control

    前言: 前面的学习基本上已经可以完成开发需求了,但是在项目中有时会遇到对请求做个缓存,当没网络的时候优先加载本地缓存,基于这个需求我们来学习一直okHttp的Cache-Control. okHttp ...

  2. Swift使用Alamofire实现网络请求

    Alamofire是一个用Swift编写的HTTP网络库,由此前热门开源项目AFNetworking的的作者mattt开发,可非常简单地用于异步网络通信. 要获取最新版本的 Alamofire,前往h ...

  3. iOS 网络请求数据缓存

    1. NSURLCache简介: iOS对NSURLRequest提供了7种缓存策略:(实际上能用的只有4种) NSURLRequestUseProtocolCachePolicy // 默认的缓存策 ...

  4. 使用Retrofit和Okhttp实现网络缓存。无网读缓存,有网根据过期时间重新请求 (转)

    使用Retrofit和Okhttp实现网络缓存,更新于2016.02.02原文链接:http://www.jianshu.com/p/9c3b4ea108a7 本文使用 Retrofit2.0.0-b ...

  5. Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类

    Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类 转载自http://www.trinea.cn/android/android-common-lib/ 介绍总结的一 ...

  6. Nohttp请求图片的两种简答的方式:普通请求以及缓存请求

    开局声明:这是基于nohttp1.0.4-include-source.jar版本写的教程 由于nohttp功能强悍,因此需要多种权限,仅仅一个联网的权限是不够的,如果只给了Internet的权限,去 ...

  7. Alamofire请求网络

    HTTP - GET和POST请求- 如果要传递大量数据,比如文件上传,只能用POST请求- GET的安全性比POST要差些,如果包含机密/敏感信息,建议用POST- 如果仅仅是索取数据(数据查询), ...

  8. 【Java/Android性能优 7】Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类

    本文转自:http://www.trinea.cn/android/android-common-lib/ 介绍总结的一些android公共库,包含缓存(图片缓存.预取缓存.网络缓存).公共View( ...

  9. Android请求网络共通类——Hi_博客 Android App 开发笔记

    今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...

随机推荐

  1. android登陆接口调试

    最近项目要开始调API,于是自己写了个关于登陆界面调试的Demo,为了保护项目,接口文档里面的内容都是被我改过的,不涉及任何项目内容.当然,代码在运行成功后,上传至博客前,相应内容我也根据改过后的文档 ...

  2. 纯 Swift 封装的 SQLite 框架:SQLite.swift

    SQLite.swift 是一个使用纯 Swift 语言封装 SQLite3 的操作框架. 特性: 简单的查询和参数绑定接口 安全.自动类型数据访问 隐式提交和回滚接口 开发者友好的错误处理和调试 文 ...

  3. 解决ASP.NET Web API Json对象循环参考错误

    前言 一般我们在开法 ASP.NET Web API 时,如果是使用 Entity Framework 技术来操作数据库的话,当两个 Entity 之间包含导览属性(Navigation Proper ...

  4. 【TCP/IP 合约】 TCP/IP 基金会

    总结 : 通过学习 TCP/IP 基础, 并总结相关笔记 和 绘制思维导图 到博客上, 对 TCP/IP 框架有了大致了解, 之后開始详细学习数据链路层的各种细节协议, 并作出笔记; 博客地址 : h ...

  5. 学习json-rpc

    最近做一个和SmartHome相关的项目,文档不全不说,连个像样的Demo都没,痛苦!!当然,这是题外话.今天来说说项目中主要用到的通讯协议:json-rpc,简单地说,它是以json格式进行的远程调 ...

  6. HDU 3874 离线段树

    在所有数字的统计范围,,对于重复统计只有一次 离线段树算法 排序终点坐标.然后再扫,反复交锋.把之前插入树行被删除 #include "stdio.h" #include &quo ...

  7. 6-06. 理性任务调度(25)(拓扑排序啊 ZJU_PAT)

    主题链接:http://pat.zju.edu.cn/contests/ds/6-06 假定一个project项目由一组子任务构成,子任务之间有的能够并行运行.有的必须在完毕了其他一些子任务后才干运行 ...

  8. NYoj-Binary String Matching-KMP算法

    Binary String Matching 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描写叙述 Given two strings A and B, whose alp ...

  9. 解决一bug的流程复盘

    听同事说有一个功能不好使了,当时有事,过了一段时间来看看这个bug 解决问题时,看的是老的日志,根据老日志看来看去没有发现问题,觉得很困惑 然后手动执行了一下,发现问题没有重现.与另一个团队的同事沟通 ...

  10. (大数据工程师学习路径)第二步 Vim编辑器----查找替换

    一.字符的替换及撤销(Undo操作) 1.替换和撤销(Undo)命令 替换和Undo命令都是针对普通模式下的操作 命令 说明 r+<待替换字母> 将游标所在字母替换为指定字母 R 连续替换 ...