Alamofire4.x开源代码分析(四)Timeline和cURL Command Output

Stella981
• 阅读 756

Timeline(时间统计)

Timeline是Alamofire提供的贯穿整个request生命周期的时间统计方案,可以通过response.timeline来访问.

Alamofire.request("https://httpbin.org/get").responseJSON { response in
    print(response.timeline)
}

如下打印

Timeline: 
    { 
    "Latency": 1.474 secs, //请求到服务器响应
    "Request Duration": 1.478 secs,//请求开始到完成
    "Serialization Duration": 0.013 secs,//序列化时间
    "Total Duration": 1.491 secs //总时间
      }

URL Session Task Metrics

在iOS10中,苹果提供了URLSessionTaskMetrics的API,和timeline非常相似,它支持更多的统计数据,并支持任何类型的响应.

Alamofire.request("https://httpbin.org/get").responseJSON { response in
    //版本限定
    if #available(iOS 10.0, *) {
        print(response.metrics)
    }
}


Request) <NSURLRequest: 0x60000001f9a0> { URL: https://httpbin.org/get }
(Response) <NSHTTPURLResponse: 0x600000223f60> { URL: https://httpbin.org/get } { status code: 200, headers {
    "Access-Control-Allow-Credentials" = true;
    "Access-Control-Allow-Origin" = "*";
    Connection = "keep-alive";
    "Content-Length" = 375;
    "Content-Type" = "application/json";
    Date = "Tue, 04 Jul 2017 00:43:51 GMT";
    Server = "meinheld/0.6.1";
    Via = "1.1 vegur";
    "X-Powered-By" = Flask;
    "X-Processed-Time" = "0.00100803375244";
} }
(Fetch Start) 2017-07-04 00:43:54 +0000
(Domain Lookup Start) 2017-07-04 00:43:54 +0000
(Domain Lookup End) 2017-07-04 00:43:54 +0000
(Connect Start) 2017-07-04 00:43:54 +0000
(Secure Connection Start) 2017-07-04 00:43:55 +0000
(Secure Connection End) 2017-07-04 00:43:55 +0000
(Connect End) 2017-07-04 00:43:55 +0000
(Request Start) 2017-07-04 00:43:55 +0000
(Request End) 2017-07-04 00:43:55 +0000
(Response Start) 2017-07-04 00:43:55 +0000
(Response End) 2017-07-04 00:43:55 +0000
(Protocol Name) http/1.1
(Proxy Connection) NO
(Reused Connection) NO
(Fetch Type) Network Load

cURL Command Output(输出请求url)

开发过程中我们都有自己拼接参数到url的经历,幸运的是Alamofire实现调试过程中直接输出请求url和参数,方便了我们在xcode以外做接口调试,比如浏览器,postman等工具.

let request = Alamofire.request("https://httpbin.org/get", parameters: ["foo": "bar"])
debugPrint(request)

输出

$ curl -i \
    -H "User-Agent: Alamofire/4.0.0" \
    -H "Accept-Encoding: gzip;q=1.0, compress;q=0.5" \
    -H "Accept-Language: en;q=1.0,fr;q=0.9,de;q=0.8,zh-Hans;q=0.7,zh-Hant;q=0.6,ja;q=0.5" \
    "https://httpbin.org/get?foo=bar"
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
ES6 新增的数组的方法
给定一个数组letlist\//wu:武力zhi:智力{id:1,name:'张飞',wu:97,zhi:10},{id:2,name:'诸葛亮',wu:55,zhi:99},{id:3,name:'赵云',wu:97,zhi:66},{id:4,na
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这