NSURLSession详解

     // MARK: - /* 使用NSURLSessionDataTask加载数据 */
     func sessionLoadData()
     {
         //创建NSURL对象
         var url:NSURL! = NSURL(string: "http://m.weather.com.cn/data/101010100.html")

         //创建请求对象
         var request : NSURLRequest = NSURLRequest(URL: url)

         let session = NSURLSession.sharedSession()

         var dataTask = session.dataTaskWithRequest(request, completionHandler: { (var data:NSData?, var response:NSURLResponse?, var error:NSError?) -> Void in

             //返回错误信息情况
             if (error != nil)
             {
                 println(error?.code)
                 println(error?.description)
             }else
             {
                 var jsonString = NSString(data: data!, encoding: NSUTF8StringEncoding)
                 println(jsonString)
             }
         }) as NSURLSessionTask

         //使用resume方法启动任务
         dataTask.resume()
     }

     // MARK: - /* 使用NSURLSessionDataTask下载文件  ---- 简单下载,不需要知道下载进度 */
     func sessionSimpleDownload()
     {
         //下载地址
         var url = NSURL(string: "http://www.iphonetrain.com/shop/data/ios/201404/source/2809080296130100.jpg")
         //请求
         var request = NSURLRequest(URL: url!)
         //连接
         var session = NSURLSession.sharedSession()
         //下载任务
         var downloadTask = session.downloadTaskWithRequest(request, completionHandler: { (var location:NSURL?,var response:NSURLResponse?, var error:NSError?) -> Void in

             // 输出下载文件原来的存放目录
             println("location: \(location)")

             //location位置转换
             var locationPath = location?.path

             //拷贝到我们自己目录中
             let documents:String = NSHomeDirectory() + "/Documents/1.png"

             // 创建文件管理器
             var fileManager :NSFileManager = NSFileManager.defaultManager()
             fileManager.moveItemAtPath(locationPath!, toPath: documents, error: nil)
             println("location: \(documents)")
         })

         //使用resume方法启动任务
         downloadTask.resume()
     }

     // MARK: - /* 使用NSURLSessionDataTask下载文件  ---- 获取进度 */
     //创建一个下载模式--单利实现
     func currentSession()->NSURLSession{

         var predicate:dispatch_once_t =
         var currentSession:NSURLSession? = nil

         dispatch_once(&predicate,{

             var config = NSURLSessionConfiguration.defaultSessionConfiguration()

             currentSession = NSURLSession(configuration: config, delegate: self, delegateQueue: nil)
             }
         )
         return currentSession!
     }

     func sessionSeniorDownload()
     {
         //下载地址
         var url = NSURL(string: "http://www.iphonetrain.com/shop/data/ios/201404/source/2809080296130100.jpg")
         //请求
         var request = NSURLRequest(URL: url!)

         //连接
         var session = currentSession() as NSURLSession

         //下载任务
         var downloadTask = session.downloadTaskWithRequest(request)

         //使用resume方法启动任务
         downloadTask.resume()
     }

      // MARK: - NSURLSessionDownloadDelegate
     func URLSession(session: NSURLSession, downloadTask: NSURLSessionDownloadTask, didFinishDownloadingToURL location: NSURL)
     {
         //下载结束
         println("下载结束")

     }
     func URLSession(session: NSURLSession, downloadTask: NSURLSessionDownloadTask, didWriteData bytesWritten: Int64, totalBytesWritten: Int64, totalBytesExpectedToWrite: Int64)
     {
         //获取进度
          var written:CGFloat = (CGFloat)(bytesWritten)
          var total:CGFloat = (CGFloat)(totalBytesExpectedToWrite)

         var pro:CGFloat = written / total
         println("下按进度:\(pro)")
     }
     func URLSession(session: NSURLSession, downloadTask: NSURLSessionDownloadTask, didResumeAtOffset fileOffset: Int64, expectedTotalBytes: Int64)
     {
         //下载偏移,主要用于暂停续传
     }

     // MARK: -  /* 使用NSURLSessionDataTask上传文件 */
     func sessionUpload()
     {
         //上传的位置地址
         var url = NSURL(string: "http://www.iphonetrain.com/shop/data/")

         //请求
         var request = NSURLRequest(URL: url!)

         //连接
         var session = NSURLSession.sharedSession()

         //上传数据流
         let documents:String = NSHomeDirectory() + "/Documents/1.png"
         var imgData = NSData(contentsOfFile: documents)

         var uploadTask = session.uploadTaskWithRequest(request, fromData: imgData, completionHandler: { (var data:NSData?, var response:NSURLResponse?, var error:NSError?) -> Void in

             //上传完毕之后判断
             println("上传完毕")
         })

         //使用resume方法启动任务
         uploadTask.resume()
     }
 

iOS开发——网络编程Swift篇&(七)NSURLSession详解的更多相关文章

  1. iOS开发——网络编程Swift篇&Alamofire详解

    Alamofire详解 预览图 Swift Alamofire 简介 Alamofire是 Swift 语言的 HTTP 网络开发工具包,相当于Swift实现AFNetworking版本. 当然,AF ...

  2. iOS开发——网络编程Swift篇&(八)SwiftyJSON详解

    SwiftyJSON详解 最近看了一些网络请求的例子,发现Swift在解析JSON数据时特别别扭,总是要写一大堆的downcast(as?)和可选(Optional),看?号都看花了.随后发现了这个库 ...

  3. iOS开发——网络编程Swift篇&(二)同/异&步请求

    同/异&步请求 同步: // MARK: - 同步请求 func httpSynchronousRequest() { //创建NSURL对象 var url:NSURL! = NSURL(s ...

  4. iOS开发——网络编程Swift篇&(一)网络监测

    网络监测 enum ReachabilityType { case WWAN, WiFi, NotConnected } public class Reachability { /** :see: O ...

  5. iOS开发——网络编程Swift篇&(六)异步Post方式

    异步Post方式 // MARK: - 异步Post方式 func asynchronousPost() { //创建NSURL对象 var url:NSURL! = NSURL(string: &q ...

  6. iOS开发——网络编程Swift篇&(五)同步Post方式

    同步Post方式 // MARK: - 同步Post方式 func synchronousPost() { //创建NSURL对象 var url:NSURL! = NSURL(string: &qu ...

  7. iOS开发——网络编程Swift篇&(四)异步Get方式

    异步Get方式 // MARK: - 异步Get方式 func asynchronousGet() { //创建NSURL对象 var url:NSURL! = NSURL(string: " ...

  8. iOS开发——网络编程Swift篇&(三)同步Get方式

    同步Get方式 // MARK: - 同步Get方式 func synchronousGet() { //创建NSURL对象 var url:NSURL! = NSURL(string: " ...

  9. iOS开发——网络编程OC篇&Socket编程

    Socket编程 一.网络各个协议:TCP/IP.SOCKET.HTTP等 网络七层由下往上分别为物理层.数据链路层.网络层.传输层.会话层.表示层和应用层. 其中物理层.数据链路层和网络层通常被称作 ...

随机推荐

  1. Android欢迎界面的创建方法

    1.制作一张启动图片splash.png,放置在res->drawable-hdpi文件夹中.2.新建布局文件splash.xml <?xml version="1.0" ...

  2. ubuntu下安装selenium2.0 环境

    参考:http://www.cnblogs.com/fnng/archive/2013/05/29/3106515.html ubuntu 安装过程: 1.安装:setuptools $ apt-ge ...

  3. Hie with the Pie(POJ 3311状压dp)

    题意:披萨店给n个地方送披萨,已知各地方(包括披萨店)之间花费的时间,求送完所有地方并回到店花费的最小时间 分析:状态好确定dp[i][j],i中1表示地方已送过,否则为0,j为当前状态最后一个送过的 ...

  4. word编号库中找不到带圈编号“①②③......"了怎么办?

    进入“Word选项/语言”对话框: 找到“朝鲜语”并将它添加到编辑语言的列表框中,无需设置为启用状态或默认编辑语言: 退出并重新启动Word: 再次打开“定义新编号格式”对话框则可以在“编号样式”下拉 ...

  5. 【C++对象模型】构造函数语意学之二 拷贝构造函数

    关于默认拷贝构造函数,有一点和默认构造函数类似,就是编译器只有在[需要的时候]才去合成默认的拷贝构造函数. 在什么时候才是[需要的时候]呢? 也就是类不展现[bitwise copy semantic ...

  6. ARM指令集----杂项指令

    ARM指令集可以分为6类,即是跳转指令,数据处理指令,程序状态传输指令,Load.Store指令,协处理器指令和异常中断指令 跳转指令: 在ARM中有两种方式可以实现程序的跳转,一种是跳转指令,另一种 ...

  7. SVM原理简介

    本文只是简单介绍一下SVM的理论框架,想要详细了解当中细节问题处理可以参看后续章节或者网上各种详细资料.推荐Andrew Ng的斯坦福大学机器学习课程. 年代中期发展起来的基于统计学习理论的一种机器学 ...

  8. Merkle Tree算法详解

    转载自:http://blog.csdn.net/yuanrxdu/article/details/22474697Merkle Tree是Dynamo中用来同步数据一致性的算法,Merkle Tre ...

  9. Codeforces 375

    A 7的所有的余数都可以用1,6,8,9排列得到,然后搞一下就可以了. B 可以用类似于单调队列的东西搞.具体看代码: /* * Problem: B. Maximum Submatrix 2 * A ...

  10. POJ 2446 Chessboard (二分图最大匹配)

    题目链接:http://poj.org/problem?id=2446 给你一个n*m的棋盘,其中有k个洞,现在有1*2大小的纸片,纸片不能覆盖洞,并且每个格子最多只能被覆盖一次.问你除了洞口之外这个 ...