首先确保在项目中已经安装了所需的第三方库。
点击【Podfile】,查看安装配置文件。
1 source ‘https://github.com/CocoaPods/Specs.git‘ 2 platform :ios,‘12.0‘ 3 use_frameworks! 4 5 target ‘DemoApp’ do 6 pod ‘Alamofire‘,‘~> 4.0‘ 7 end
根据配置文件中的相关配置,安装第三方库。
然后点击打开【DemoApp.xcworkspace】项目文件。
在项目导航区,打开视图控制器的代码文件【ViewController.swift】
现在开始编写代码,实现一个简单的功能:下载一个文件,并将该文件存储在沙箱中。
1 import UIKit 2 //在当前的类文件中,引入已经安装的第三方类库 3 import Alamofire 4 5 class ViewController: UIViewController { 6 //视图加载完成的方法 7 override func viewDidLoad() { 8 super.viewDidLoad() 9 // Do any additional setup after loading the view,typically from a nib. 10 //简单的图片下载功能 11 simpleDownload() 12 13 //实时显示下载进度的图片下载功能 14 complexDownload() 15 } 16 17 //添加一个方法, 18 //通过访问服务器的接口,下载并保存一个文本文件 19 func simpleDownload() 20 { 21 //初始化一个下载请求对象,并设置下载后的存储目录,位于沙箱的文档目录中。 22 let destination = DownloadRequest.suggestedDownloadDestination( 23 for: .documentDirectory,24 in: .userDomainMask 25 ) 26 //在控制台输出沙箱中的文档目录, 27 //使用这条日志信息,进入该目录并查看下载后的文件。 28 print(NSHomeDirectory()+"/Documents") 29 30 //调用网络操作库的下载方法,下载指定的服务器接口, 31 //并将下载后的文件存储在指定的目录中。 32 let result = Alamofire.download("https://httpbin.org/stream/1",to: destination) 33 //控制台输出结果 34 print(result) 35 } 36 37 //添加一个方法, 38 //实现一个可实时显示下载进度的图片下载功能 39 func complexDownload() 40 { 41 //初始化一个下载请求对象,并设置下载后的存储目录,位于沙箱的文档目录中。 42 let destination = DownloadRequest.suggestedDownloadDestination( 43 for: .documentDirectory,44 in: .userDomainMask 45 ) 46 47 //还可以设置服务器接口的请求参数 48 let parameters: Parameters = ["foo": "bar"] 49 50 //调用网络操作库的下载方法,下载指定的服务器接口, 51 //并将下载后的文件存储在指定的目录中。 52 Alamofire.download("http://images.apple.com/v/home/cx/images/gallery/iphone_large_2x.jpg",53 method: .get,54 parameters: parameters,55 encoding: JSONEncoding.default,56 to: destination) 57 //通过一个下载进度方法块,处理图片下载的事件 58 .downloadProgress(queue: dispatchQueue.global()) 59 { 60 progress in 61 //在控制台输出:进度的完成比例 62 print("Progress1: \(progress.fractionCompleted)") 63 //在控制台输出:已经下载的字节数 64 print("Progress2: \(progress.completedUnitCount)") 65 //在控制台输出:全部的字节数 66 print("Progress3: \(progress.totalUnitCount)") 67 } 68 //完成的图片的下载后执行验证方法,此处返回成功标识 69 .validate { request,response,temporaryURL,destinationURL in 70 return .success 71 } 72 //处理图片下载后的返回信息 73 .responseJSON { response in 74 //在控制台输出:网络返回对象 75 debugPrint("response:\(response)") 76 //在控制台输出:图片下载临时存放的位置 77 print("response.temporaryURL:\(response.temporaryURL)") 78 //在控制台输出:下载后的存储位置 79 print("response.destinationURL:\(response.destinationURL)") 80 } 81 } 82 83 override func didReceiveMemoryWarning() { 84 super.didReceiveMemoryWarning() 85 // dispose of any resources that can be recreated. 86 } 87 }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。