前言
本简书主要介绍Alamofire的文件上传,Alamofire的一些基本使用就基本带过,如果还有不理解的可以观看74-Swift之Alamofire的基本使用和介绍(GET/POST)。
Alamofire 的文件上传使用
1、Alamofire 的基本上传和返回结果的数据解析
/**
TODO: 二进制流的形式上传
@data : 上传文件的数据对象
@URLConvertible : 上传的地址
注意: data的类型是Data,不能直接使用 NSData类型的对象。否则会出现 “Cannot invoke 'upload' with an argument list of type '(NSData?, to: String)'”错误提示。
*/
let dataPath = Bundle.main.path(forResource: "upDataName", ofType: "upDataSuffix")
let upData = NSData.init(contentsOfFile: dataPath!)
let upLoadRequest:UploadRequest = Alamofire.upload(Data.init(referencing: upData!), to: "https://network.net/upload")
// 上面的请求返回一个 “UploadRequest” 对象。我们可以对其进行解析,Alamofire请求数据解析的方法都使用与它。
upLoadRequest.validate().response { (DDataRequest) in
if let acceptData = DDataRequest.data {
print(String.init(data: acceptData, encoding: String.Encoding.utf8)!)
}
if DDataRequest.error != nil {
print("上传失败!!!")
}
}
upLoadRequest.validate().responseJSON { (DataResponse) in
if DataResponse.result.isSuccess {
print(String.init(data: DataResponse.data!, encoding: String.Encoding.utf8)!)
}
if DataResponse.result.isFailure {
print("上传失败!!!")
}
}
upLoadRequest.validate().responseString { (DataResponse) in
if DataResponse.result.isSuccess {
print(String.init(data: DataResponse.data!, encoding: String.Encoding.utf8)!)
}
if DataResponse.result.isFailure {
print("上传失败!!!")
}
}
upLoadRequest.validate().responsePropertyList { (DataResponse) in
if DataResponse.result.isSuccess {
print(String.init(data: DataResponse.data!, encoding: String.Encoding.utf8)!)
}
if DataResponse.result.isFailure {
print("上传失败!!!")
}
}
upLoadRequest.validate().response(queue: DispatchQueue.main) { (DDataRequest) in
if let acceptData = DDataRequest.data {
print(String.init(data: acceptData, encoding: String.Encoding.utf8)!)
}
if DDataRequest.error != nil {
print("上传失败!!!")
}
}
2、Alamofire 带进度的文件上传
/**
TODO: 二进制流的形式上传
@data : 上传文件的数据对象
@URLConvertible : 上传的地址
注意: data的类型是Data,不能直接使用 NSData类型的对象。否则会出现 “Cannot invoke 'upload' with an argument list of type '(NSData?, to: String)'”错误提示。
*/
let dataPath = Bundle.main.path(forResource: "upDataName", ofType: "upDataSuffix")
let upData = NSData.init(contentsOfFile: dataPath!)
let upLoadRequest:UploadRequest = Alamofire.upload(Data.init(referencing: upData!), to: "https://network.net/upload")
/**
可获取上传进度
*/
upLoadRequest.uploadProgress { (progress) in
// 上传进度
print(progress.fractionCompleted)
}
upLoadRequest.uploadProgress(queue: DispatchQueue.main) { (progress) in
// 上传进度
print(progress.fractionCompleted)
}
Alamofire 上传类型的举例
Alamofire 上传支持一下类型:
- Data 数据流
- File 文件路径
- stream 输入流
- multipartFormData 多文件上传
1、Alamofire的Data 类型的上传
/**
TODO: 二进制流的形式上传
@data : 上传文件的数据对象
@URLConvertible : 上传的地址
注意: data的类型是Data,不能直接使用 NSData类型的对象。否则会出现 “Cannot invoke 'upload' with an argument list of type '(NSData?, to: String)'”错误提示。
*/
let dataPath = Bundle.main.path(forResource: "upDataName", ofType: "upDataSuffix")
let upData = NSData.init(contentsOfFile: dataPath!)
let upLoadRequest:UploadRequest = Alamofire.upload(Data.init(referencing: upData!), to: "https://network.net/upload")
// 上面的请求返回一个 “UploadRequest” 对象。我们可以对其进行解析,Alamofire请求数据解析的方法都使用与它。
upLoadRequest.validate().response { (DDataRequest) in
if let acceptData = DDataRequest.data {
print(String.init(data: acceptData, encoding: String.Encoding.utf8)!)
}
if DDataRequest.error != nil {
print("上传失败!!!")
}
}
2、Alamofire的File类型的上传
/**
TODO: 通过文件路径上传
@fileURL : 上传文件的路径
@URLConvertible : 上传文件的网址
注意: fileURL 要转化一下,否则会报 “Cannot invoke 'upload' with an argument list of type '(String, to: String)'”错。
*/
Alamofire.upload(URL.init(fileURLWithPath: dataPath!), to: "https://network.net/upload").validate().responseData { (DDataRequest) in
if DDataRequest.result.isSuccess {
print(String.init(data: DDataRequest.data!, encoding: String.Encoding.utf8)!)
}
if DDataRequest.result.isFailure {
print("上传失败!!!")
}
}
3、Alamofire的Stream 形式上传
/**
TODO: 通过输入流上传数据
@stream : 数据输入流对象
@URLConvertible 上传的网址
*/
let inPutStraeam = InputStream.init(data: upData! as Data)
Alamofire.upload(inPutStraeam, to: "https://network.net/upload").validate().responseData { (DDataRequest) in
if DDataRequest.result.isSuccess{
let acceptData = DDataRequest.data
print(String.init(data: acceptData!, encoding: String.Encoding.utf8)!)
}
if DDataRequest.result.isFailure {
print("上传失败!!!")
}
}
4、 Alamofire的multipartFormData 形式上传
/**
TODO: 多部分数据上传
*/
Alamofire.upload(multipartFormData: { (MFData) in
MFData.append(upData! as Data, withName: "NetWork")
MFData.append(upData! as Data, withName: "NetWork小贱")
}, to: "https://network.net/upload") { (SMResult) in
switch SMResult {
case .success(let request, let streamingFromDisk, let streamFileURL):
print(streamFileURL!,request,streamingFromDisk)
request.responseJSON(completionHandler: { (DResponse) in
if DResponse.result.isSuccess {
print("上传成功!!!")
}
})
break
case .failure(_):
print("上传失败!!!")
break
}
}
Alamofire 可定义请求类型的上传
1、 Data 类型请求上传
/**
TODO: 可以自定义请求的二进制流上传
*/
let uploadRequest = URLRequest.init(url: URL.init(fileURLWithPath: dataPath!), cachePolicy: .reloadIgnoringCacheData, timeoutInterval: 20)
Alamofire.upload(upData! as Data , with:uploadRequest).validate().responseJSON { (dataResponse) in
if dataResponse.result.isSuccess {
let acceptData = dataResponse.data
print(String.init(data: acceptData!, encoding: String.Encoding.utf8)!)
}
if dataResponse.result.isFailure {
print("上传失败!!!")
}
}
2、File 类型的请求上传
/**
TODO: 可以自定义请求的数据路径形式上传
*/
Alamofire.upload(URL.init(fileURLWithPath: dataPath!), with: uploadRequest).validate().response(queue: DispatchQueue.main) { (DDResponse) in
if let acceptData = DDResponse.data {
print(String.init(data: acceptData, encoding: String.Encoding.utf8)!)
}
if DDResponse.error != nil {
print("上传失败!!!")
}
}
3、Stream 类型的上传
/**
TODO: 可以自定义请求的数据输入流形式上传
*/
Alamofire.upload(inPutStraeam, with: uploadRequest).validate().responseJSON { (DataResponse) in
if DataResponse.result.isSuccess {
print("上传成功")
}
if DataResponse.result.isFailure {
print("上传失败!!!")
}
}
4、multipartFormData 类型的上传
/**
TODO: 可定义请去形式的多部分上传
*/
Alamofire.upload(multipartFormData: { (MFData) in
MFData.append(upData! as Data, withName: "NetWork")
MFData.append(upData! as Data, withName: "NetWork小贱")
}, with: uploadRequest) { (SMResult) in
switch SMResult {
case .success(let request, let streamingFromDisk, let streamFileURL):
print(streamFileURL!,request,streamingFromDisk)
request.responseJSON(completionHandler: { (DResponse) in
if DResponse.result.isSuccess {
print("上传成功!!!")
}
})
break
case .failure(_):
print("上传失败!!!")
break
}
}
Alamofire 的可定义请求和头文件和请求方式的上传
1、data 类型
/**
TODO: 通过数据流的形式,并可设置上传方式和头文件的上传
@data 上传数据流
@URLConvertible 上传的网址
@method 上传的方法
@header 上传的头文件
*/
Alamofire.upload(upData! as Data, to: "https://network.net/upload", method: .post, headers: ["":""]).validate().responseJSON { (DataResponse) in
if DataResponse.result.isSuccess {
print(String.init(data: DataResponse.data!, encoding: String.Encoding.utf8)!)
}
if DataResponse.result.isFailure {
print("上传失败!!!")
}
}
2、Fire 类型
/**
TODO: 通过上传数据的路径,并可设置上传方式和头文件的上传
@fileURL 上传数据路径
@URLConvertible 上传的网址
@method 上传的方法
@header 上传的头文件
*/
Alamofire.upload(URL.init(fileURLWithPath: dataPath!), to: "https://network.net/upload", method: .post, headers: ["":""]).validate().responseString { (DataResponse) in
if DataResponse.result.isSuccess {
print(String.init(data: DataResponse.data!, encoding: String.Encoding.utf8)!)
}
if DataResponse.result.isFailure {
print("上传失败!!!")
}
}
3、stream 类型
/**
TODO: 通过输入流上传数据,并可指定上传方式和上传请求头
@stream : 数据输入流对象
@URLConvertible 上传的网址
@method 上传的方法
@header 上传的头文件
*/
Alamofire.upload(inPutStraeam, to: "https://network.net/upload", method: .post, headers: ["":""]).validate().response(queue: DispatchQueue.main) { (DDataRespose) in
if let acceptData = DDataRespose.data {
print(String.init(data: acceptData, encoding: String.Encoding.utf8)!)
}
if DDataRespose.error != nil {
print("上传失败!!!")
}
}
4、 multipartFormData 类型
/**
TODO: 可定义请去形式和内存阈值的多部分上传
*/
Alamofire.upload(multipartFormData: { (MFData) in
MFData.append(upData! as Data, withName: "NetWork")
MFData.append(upData! as Data, withName: "NetWork小贱")
}, usingThreshold: 8283, to: "https://network.net/upload", method: .post, headers: ["":""]) { (SMResult) in
switch SMResult {
case .success(let request, let streamingFromDisk, let streamFileURL):
print(streamFileURL!,request,streamingFromDisk)
request.responseJSON(completionHandler: { (DResponse) in
if DResponse.result.isSuccess {
print("上传成功!!!")
}
})
break
case .failure(_):
print("上传失败!!!")
break
}
}
Alamofire 可设置内存阈值的上传
/**
TODO: 可以设置请求和内存阈值的多部分数据上传
*/
Alamofire.upload(multipartFormData: { (MFData) in
MFData.append(upData! as Data, withName: "NetWork")
MFData.append(upData! as Data, withName: "NetWork小贱")
}, usingThreshold: 8283, with: uploadRequest) { (SMResult) in
switch SMResult {
case .success(let request, let streamingFromDisk, let streamFileURL):
print(streamFileURL!,request,streamingFromDisk)
request.responseJSON(completionHandler: { (DResponse) in
if DResponse.result.isSuccess {
print("上传成功!!!")
}
})
break
case .failure(_):
print("上传失败!!!")
break
}
}
/**
TODO: 可定义请去形式和内存阈值的多部分上传
*/
Alamofire.upload(multipartFormData: { (MFData) in
MFData.append(upData! as Data, withName: "NetWork")
MFData.append(upData! as Data, withName: "NetWork小贱")
}, usingThreshold: 8283, to: "https://network.net/upload", method: .post, headers: ["":""]) { (SMResult) in
switch SMResult {
case .success(let request, let streamingFromDisk, let streamFileURL):
print(streamFileURL!,request,streamingFromDisk)
request.responseJSON(completionHandler: { (DResponse) in
if DResponse.result.isSuccess {
print("上传成功!!!")
}
})
break
case .failure(_):
print("上传失败!!!")
break
}
}