当前位置: 首页 > 编程笔记 >

Swift网络请求库Alamofire使用详解

公羊俭
2023-03-14
本文向大家介绍Swift网络请求库Alamofire使用详解,包括了Swift网络请求库Alamofire使用详解的使用技巧和注意事项,需要的朋友参考一下

前言

Alamofire是一个使用Swift开发的网络请求库,其开发团队是AFNetworking的原团队。它语法简洁,采用链式编程的思想,使用起来是相当的舒服。本质是基于NSURLSession进行封装。接下开我们就进入实战,开始学习Alamofire的使用。

GET请求

常用的get请求示例以及请求结果

 Alamofire.request("https://httpbin.org/get", method: .get, parameters: nil, encoding: URLEncoding.default, headers: nil).responseJSON { (response) in
  if(response.error == nil){
  LLog("请求成功")
  LLog(response.result.value)
  }else{
  LLog("请求失败\(String(describing: response.error))")
  }

 }

Get请求、有参数、使用Basic Auth授权访问(例如:jira)

var header:HTTPHeaders = [:]
 if let authorizationHeader = Request.authorizationHeader(user: "xxxx", password: "xxxxxx") {
  header[authorizationHeader.key] = authorizationHeader.value
 }
 // 此处的 URLEncoding.default (URLEncoding.queryString )会将parameters 拼接到url后面
 Alamofire.request("https://httpbin.org/get", method: HTTPMethod.get, parameters: ["key":"value"], encoding: URLEncoding.default, headers: header).responseJSON { (response) in
  if(response.error == nil){
  LLog("请求成功")
  LLog(response.result.value)
  }else{
  LLog("请求失败\(String(describing: response.error))")
  }

 }

POST请求 常用的post请求

Alamofire.request("https://httpbin.org/post", method: .post, parameters: ["key1":"value1","key2":"value2"], encoding: URLEncoding.default, headers: nil).responseJSON { (response) in

   if(response.error == nil){
    LLog("请求成功")
    LLog(response.result.value)
   }else{
    LLog("请求失败\(String(describing: response.error))")
   }

  }

post请求,提交json格式的数据

// JSONEncoding.default === JSONEncoding.prettyPrinted
 Alamofire.request("https://httpbin.org/post", method: .post, parameters: ["key1":"value1","key2":"value2"], encoding: JSONEncoding.default, headers: nil).responseJSON { (response) in

   if(response.error == nil){
    LLog("请求成功")
    LLog(response.result.value)
   }else{
    LLog("请求失败\(String(describing: response.error))")
   }

  }

PUT、Delete 请求 参照POST(使用区别不大)

UPLOAD(上传文件)

上传文件示例

 let data:Data = UIImageJPEGRepresentation(#imageLiteral(resourceName: "beauty.jpeg"), 0.2)!
  let url = Bundle.main.url(forResource: "beauty", withExtension: "jpeg");
  // 多文件上传
  Alamofire.upload(multipartFormData: { (formdata) in

   formdata.append(data, withName: "file", fileName: "beauty.jpeg", mimeType: "image/jpeg") 
   formdata.append(url!, withName: "file2")

  }, to: UPLOAD_URL) { (encodingResult) in

   switch encodingResult{
   case .success(let uploadFile, _, _):
    //上传进度回调
    uploadFile.uploadProgress(closure: { (progress) in
     debugPrint("上传进度\(progress)")
    })
    //上传结果回调
    uploadFile.responseString(completionHandler: { (response) in
     LLog(response.result.value)
    })

    break
   case .failure( let error):
    LLog(error);
    break
   }

  }

备注:

想必大家也注意到上面的上传图片的代码,在append data的时候多了一个 filename的参数,在测试的时候,我发现这个参数是必须的,如果你传入的是data数据,但是如果你使用的是fileurl则可以不用这个参数,在alamofire中 会自己获取文件的名。


如果我们在append data的时候,不传入文件名,在上面的代码中 headers中则不会有 filename这个参数,此时使用charles抓包是会发现如下。

上传文件并携带参数

var param: [String:String] = [:];
  param["postion"] = "portrait"
  let url = Bundle.main.url(forResource: "beauty", withExtension: "jpeg");
  // 2、多文件上传
  Alamofire.upload(multipartFormData: { (formdata) in
   formdata.append(url!, withName: "file2")

   //拼接参数
   for (key, value) in param {
    formdata.append(value.data(using: String.Encoding.utf8)!, withName: key)
   }

  }, to: UPLOAD_URL) { (encodingResult) in

   switch encodingResult{
   case .success(let uploadFile, _, _):
    //上传进度回调
    uploadFile.uploadProgress(closure: { (progress) in
     debugPrint("上传进度\(progress)")
    })
    //上传结果回调
    uploadFile.responseJSON(completionHandler: { (response) in
     LLog(response.result.value)
    })

    break
   case .failure( let error):
    LLog(error);
    break
   }



  }

 

备注:在我们的实际开发中,后台有时候并没有配置专门的文件服务器,这个时候我们往往就需要在上传文件的时候,配置必要的参数,来表明我们上传文件资源的目的。

最后

Alamofire真的是一个很好用的网络请求库,同学们,赶紧开始使用吧!

 类似资料:
  • 本文向大家介绍IOS网络请求之AFNetWorking 3.x 使用详情,包括了IOS网络请求之AFNetWorking 3.x 使用详情的使用技巧和注意事项,需要的朋友参考一下 前言: 计划把公司的网络请求与业务解耦,所以想着学习一下网络请求,最近学习了NSURLSession,今天来学习一下基于NSURLSession封装的优秀开源框架AFNetWorking 3.x,之前13年做iOS开发时

  • Mpx提供了网络请求库fetch,抹平了微信,阿里等平台请求参数及响应数据的差异;同时支持请求拦截器,请求取消等 使用说明 import mpx from '@mpxjs/core' import mpxFetch from '@mpxjs/fetch' mpx.use(mpxFetch) // 第一种访问形式 mpx.xfetch.fetch({ url: 'http://xxx.com' }

  • 本文向大家介绍Flutter 网络请求框架封装详解,包括了Flutter 网络请求框架封装详解的使用技巧和注意事项,需要的朋友参考一下  Flutter 请求网络的三种方式 flutter 请求网络的方式有三种,分别是 Dart 原生的网络请求 HttpClient、第三方网络请求 http以及 Flutter 中的 Dio。我们可以比较一下这三种网络请求方式,然后封装为我们方便请求网络的工具类。

  • 类似于Ajax,QAP实现了Fetch功能,能够简单的异步的获取资源。 GET QN.fetch('http://121.42.141.44:8888', { body: '', method: 'GET', mode: 'same-origin', dataType: 'text', }) .then(response => { return respon

  • request 指的是小程序中的网络请求,在 mpvue 框架中可以通过小程序提供的原生 API wx.request 来进行相关的处理。但是在这里推荐一个第三方的网络请求库 fly。之所以推荐这个第三方库,是因为可以在多个端上实现代码的复用,目前已支持的有 Node.js 、微信小程序 、Weex 、React Native 、Quick App。 在 mpvue 中如何使用 安装 npm in

  • Chrome提供了较为完整的方法供扩展程序分析、阻断及更改网络请求,同时也提供了一系列较为全面的监听事件以监听整个网络请求生命周期的各个阶段。网络请求的整个生命周期所触发事件的时间顺序如下图所示。 网络请求的生命周期,图片来自developer.chrome.com 要对网络请求进行操作,需要在Manifest中声明webRequest权限以及相关被操作的URL。如需要阻止网络请求,需要声明web