转载地址:http://blog.csdn.net/abcd2686529828/article/details/51323673

说明:本文示例代码发送的请求均为http请求,需要对info.plist文件进行配置。如何配置,请参考https://github.com/HanGangAndHanMeimei/iOS9AdaptationTips

一、简单说明

   在iOS9.0之后,以前使用的NSURLConnection过期,苹果推荐使用NSURLSession来替换NSURLConnection完成网路请求相关操作.NSURLSession的使用非常简单,先根据会话对象创建一个请求Task,然后执行该Task即可。
   NSURLSessionTask本身是一个抽象类,在使用的时候,通常是根据具体的需求使用它的几个子类。关系如下:

二、发送GET请求

  使用NSURLSession发送GET请求的方法和NSURLConnection类似,整个过程如下:

    1)确定请求路径(一般由公司的后台开发人员以接口文档的方式提供),GET请求参数直接跟在URL后面

    2)创建请求对象(默认包含了请求头和请求方法【GET】),此步骤可以省略

    3)创建会话对象(NSURLSession)

    4)根据会话对象创建请求任务(NSURLSessionDataTask)

    5)执行Task //这步别忘了

    6)当得到服务器返回的响应后,解析数据(XML|JSON|HTTP)

示例代码:

发生GET请求第一种方法

func GET1()
    {
         //对请求路径的说明
        //http://120.25.226.186:32812/login?username=520it&pwd=520&type=JSON
        //协议头+主机地址+接口名称+?+参数1&参数2&参数3
        //协议头(http://)+主机地址(120.25.226.186:32812)+接口名称(login)+?+参数1(username=520it)&参数2(pwd=520)&参数3(type=JSON)
        //GET请求,直接把请求参数跟在URL的后面以?隔开,多个参数之间以&符号拼接
        //1.确定请求路径
        var url: NSURL = NSURL(string: "http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON")!
        //2.创建请求对象
        //请求对象内部默认已经包含了请求头和请求方法(GET)
        var request: NSURLRequest = NSURLRequest(URL: url)

        //3.获得会话对象
        var session: NSURLSession = NSURLSession.sharedSession()

        //4.根据会话对象创建一个Task(发送请求)
        /* 第一个参数:请求对象 第二个参数:completionHandler回调(请求完成【成功|失败】的回调) data:响应体信息(期望的数据) response:响应头信息,主要是对服务器端的描述 error:错误信息,如果请求失败,则error有值 */
        var dataTask: NSURLSessionDataTask = session.dataTaskWithRequest(request) { (data,response,error) in
            //这部分内容 可以自己处理,下面仅是个例子
            if(error == nil){
                //6.解析服务器返回的数据
                //说明:(此处返回的数据是JSON格式的,因此使用NSJSONSerialization进行反序列化处理)
                var dict:NSDictionary? = nil
                do {
                    dict  = try NSJSONSerialization.JSONObjectWithData(data!,options: NSJSONReadingOptions.init(rawValue: 0)) as! NSDictionary
                } catch {

                }
                print("%@",dict)
            }
        }
         //5.执行任务
         dataTask.resume()
     }

发生GET请求第二种方法

func GET2()

    {

        //1.确定请求路径
        var url: NSURL = NSURL(string: "http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON")!

        //2.获得会话对象
        var session: NSURLSession = NSURLSession.sharedSession()

        //3.根据会话对象创建一个Task(发送请求)
        /* 第一个参数:请求路径 第二个参数:completionHandler回调(请求完成【成功|失败】的回调) data:响应体信息(期望的数据) response:响应头信息,主要是对服务器端的描述 error:错误信息,如果请求失败,则error有值 注意: 1)该方法内部会自动将请求路径包装成一个请求对象,该请求对象默认包含了请求头信息和请求方法(GET) 2)如果要发送的是POST请求,则不能使用该方法 */
        var dataTask: NSURLSessionDataTask = session.dataTaskWithURL(url) { (data,error) in
            //5.解析数据
            var dict:NSDictionary? = nil
            do {
                dict  = try NSJSONSerialization.JSONObjectWithData(data!,options: NSJSONReadingOptions.init(rawValue: 0)) as! NSDictionary
            } catch {

            }

            print("%@",dict)
        }

         //4.执行任务
        dataTask.resume()
    }

三、发送POST请求

  使用NSURLSession发送POST请求的方法和NSURLConnection类似,整个过程如下:

    1)确定请求路径(一般由公司的后台开发人员以接口文档的方式提供)

    2)创建可变的请求对象(因为需要修改),此步骤不可以省略

    3)修改请求方法为POST

    4)设置请求体,把参数转换为二进制数据并设置请求体

    5)创建会话对象(NSURLSession)

    6)根据会话对象创建请求任务(NSURLSessionDataTask)
   7)执行Task

    8)当得到服务器返回的响应后,解析数据(XML|JSON|HTTP)

  示例代码:

//发送POST请求NSURLSession
    func POST()
    {
        //对请求路径的说明
        //http://120.25.226.186:32812/login
        //协议头+主机地址+接口名称
        //协议头(http://)+主机地址(120.25.226.186:32812)+接口名称(login)
        //POST请求需要修改请求方法为POST,并把参数转换为二进制数据设置为请求体

        //1.创建会话对象
        var session: NSURLSession = NSURLSession.sharedSession()

        //2.根据会话对象创建task
        var url: NSURL = NSURL(string: "http://120.25.226.186:32812/login")!

        //3.创建可变的请求对象
        var request: NSMutableuRLRequest = NSMutableuRLRequest(URL: url)

        //4.修改请求方法为POST
        request.HTTPMethod = "POST"

        //5.设置请求体
        request.HTTPBody = "username=520it&pwd=520it&type=JSON".dataUsingEncoding(NSUTF8StringEncoding)

        //6.根据会话对象创建一个Task(发送请求)
        /* 第一个参数:请求对象 第二个参数:completionHandler回调(请求完成【成功|失败】的回调) data:响应体信息(期望的数据) response:响应头信息,主要是对服务器端的描述 error:错误信息,如果请求失败,则error有值 */
        var dataTask: NSURLSessionDataTask = session.dataTaskWithRequest(request) { (data,error) in

            //if(error == nil){
                //8.解析数据
                //说明:(此处返回的数据是JSON格式的,因此使用NSJSONSerialization进行反序列化处理)
                var dict:NSDictionary? = nil
                do {
                    dict  = try NSJSONSerialization.JSONObjectWithData(data!,dict)
            //}
        }
        //5.执行任务
        dataTask.resume()
    }

四、NSURLSession代理方法简单介绍

有的时候,我们可能需要监听网络请求的过程(如下载文件需监听文件下载进度),那么就需要用到代理方法。接下来通过代码简单说明NSURLSession中普通网络请求会涉及代理方法的使用

private var _responseData: NSMutableData!
    var responseData: NSMutableData!{
        get{
            if _responseData == nil {
                _responseData = NSMutableData()
            }
            return _responseData
        }
        set{
            self._responseData = newValue
        }
    }

    //当点击控制器View的时候会调用该方法
    override func touchesBegan(touches: Set<UITouch>,withEvent event: UIEvent?)
    {
        self.delegatetest()
    }

    //发送请求,代理方法
    func delegatetest()
    {
        //1.确定请求路径
        var url: NSURL = NSURL(string: "http://120.25.226.186:32812/login?username=520it&pwd=520it&type=JSON")!

        //2.创建请求对象
        //请求对象内部默认已经包含了请求头和请求方法(GET)
        var request: NSURLRequest = NSURLRequest(URL: url)

        //3.获得会话对象,并设置代理
             /* 第一个参数:会话对象的配置信息defaultSessionConfiguration 表示默认配置 第二个参数:谁成为代理,此处为控制器本身即self 第三个参数:队列,该队列决定代理方法在哪个线程中调用,可以传主队列|非主队列 [NSOperationQueue mainQueue] 主队列: 代理方法在主线程中调用 [[NSOperationQueue alloc]init] 非主队列: 代理方法在子线程中调用 */
        var session: NSURLSession = NSURLSession(configuration: NSURLSessionConfiguration.defaultSessionConfiguration(),delegate: self,delegateQueue: NSOperationQueue.mainQueue())

        //4.根据会话对象创建一个Task(发送请求)
        var dataTask: NSURLSessionTask = session.dataTaskWithRequest(request)

        //5.执行任务
        dataTask.resume()
    }

    //1.接收到服务器响应的时候调用该方法
    func URLSession(session: NSURLSession,dataTask: NSURLSessionDataTask,didReceiveResponse response: NSURLResponse,completionHandler: (NSURLSessionResponsedisposition) -> Void) {

        //在该方法中可以得到响应头信息,即response
             print("didReceiveResponse--%@",NSThread.currentThread)

             //注意:需要使用completionHandler回调告诉系统应该如何处理服务器返回的数据
             //默认是取消的
             /* NSURLSessionResponseCancel = 0,默认的处理方式,取消 NSURLSessionResponseAllow = 1,接收服务器返回的数据 NSURLSessionResponseBecomeDownload = 2,变成一个下载请求 NSURLSessionResponseBecomeStream 变成一个流 */
        completionHandler(NSURLSessionResponsedisposition.Allow)
    }


    //2.接收到服务器返回数据的时候会调用该方法,如果数据较大那么该方法可能会调用多次
    func URLSession(session: NSURLSession,didReceiveData data: NSData) {

        print("didReceiveData--%@",NSThread.currentThread)

        //拼接服务器返回的数据
        self.responseData.appendData(data)
    }


    //3.当请求完成(成功|失败)的时候会调用该方法,如果请求失败,则error有值
    func URLSession(session: NSURLSession,task: NSURLSessionTask,didCompleteWithError error: NSError?) {
        print("didCompleteWithError--%@",NSThread.currentThread)

        if (error == nil) {
            //解析数据,JSON解析请参考http://www.cnblogs.com/wendingding/p/3815303.html
            var dict:NSDictionary? = nil
            do {
                dict  = try NSJSONSerialization.JSONObjectWithData(self.responseData,options: NSJSONReadingOptions.init(rawValue: 0)) as! NSDictionary
            } catch {

            }

            print("%@",dict)
        }
    }

Swift的学习(NSURLSession发送get、post请求)的更多相关文章

  1. HTML5 Web缓存和运用程序缓存(cookie,session)

    这篇文章主要介绍了HTML5 Web缓存和运用程序缓存(cookie,session),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. iOS Swift上弃用后Twitter.sharedInstance().session()?. userName的替代方案

    解决方法如果您仍在寻找解决方案,请参阅以下内容:

  3. 使用Fabric SDK iOS访问Twitter用户时间线

    我试图在这个问题上挣扎两天.我正在使用FabricSDK和Rest工具包,试图为Twitter使用不同的RestAPIWeb服务.我可以使用具有authTokenSecret,authToken和其他值的会话对象的TWTRLogInButton成功登录.当我尝试获取用户时间线时,我总是得到失败的响应,作为:{“errors”:[{“code”:215,“message”:“BadAuthentic

  4. ios – 将视频分享到Facebook

    我正在编写一个简单的测试应用程序,用于将视频从iOS上传到Facebook.由于FacebookSDK的所有文档都在Objective-C中,因此我发现很难在线找到有关如何使用Swift执行此操作的示例/教程.到目前为止我有这个在我的UI上放置一个共享按钮,但它看起来已禁用,从我读到的这是因为没有内容设置,但我看不出这是怎么可能的.我的getVideoURL()函数返回一个NSURL,它肯定包含视

  5. ios – 如何从Apple Watch调用iPhone上定义的方法

    有没有办法从Watchkit扩展中调用iPhone上的类中定义的方法?根据我的理解,目前在Watchkit和iPhone之间进行本地通信的方法之一是使用NSUserDefaults,但还有其他方法吗?

  6. ios – 错误域= NSURLErrorDomain代码= -1003“找不到具有指定主机名的服务器

    当我尝试在设备上运行应用程序时出现此错误.当我在模拟器上运行它并且post请求正常工作时,我没有收到此错误.这是我的代码片段:任何帮助表示赞赏.谢谢解决方法此错误通常会提示DNS相关问题.检查设备上的DNS设置并确认您可以使用Safari或其他浏览器浏览互联网.如果有一个url,你可以在同一台服务器上获取,尝试直接在设备上的Safari中访问它.

  7. ios – 使用NSURLSession获取JSON数据

    我试图从谷歌距离api使用NSURLSession获取数据,但如下所示,当我打印响应和数据时,我得到的结果为NULL.可能是什么问题?

  8. ios – Xcode Bot:如何在post触发器脚本上获得.ipa路径?

    我正在使用机器人来存档iOS应用程序,我需要获取.ipa产品路径才能将其发布到我们的分发系统中.机器人设置:并使用脚本打印所有env变量,其中不包含ipa文件的路径.此外,一些变量指向不存在的目录,即:XCS_OUTPUT_DIR这里的env变量输出:除此之外,我还能够确认.ipa文件是在另一个文件夹中创建的(/IntegrationAssets//

  9. ios – 尝试向我们分配IP而不是localhost或home时,NSURLSession失败

    我有一台本地运行的服务器(我的IP是192.168.0.98),并且已经尝试使用一些网络代码来访问它.最初这是通过AFNetworking完成的,但我现在用这样的NSURLSession完成了它:然后我用这3个URL运行它:>http://localhost:8080/api–>作品.>http://127.0.0.1:8080/api–>作品.>http://192.168.0.98:8080/

  10. ios – 使用CocoaPods post install hook将自定义路径添加到HEADER_SEARCH_PATHS

    解决方法在Podfile中定义一个方法:然后在post_install中调用该方法:

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部