1.CURL 简介
CURL 是一个通过 URL 传输数据的、功能强大的命令行工具,用于在服务器之间传输数据。CURL 可以与 Chrome Devtool 工具配合使用,把浏览器发送的真实请求还原出来,并附带认证信息。CURL 的功能非常强大,命令行参数多达几十种,我们可以通过修改 CURL 的参数用以获取不同的结果。除此之外,我们也可以单独使用 CURL,根据测试需求用它构造请求参数,构造多种接口测试场景。
2.Chrome Devtool 介绍
使用 CURL 工具之前,需要先了解 Chrome Devtool 工具。
Chrome DevTool(Chrome 开发者工具)是内嵌在 Chrome 浏览器里的一组用于网页制作和调试的工具。在测试的过程中,我们也常常用它作一个简单的抓包工具,操作步骤如下所示。
(1)选择 Chrome 右上角的 菜单栏,在弹出的下拉菜单中以选择“ 更多工具”→“开发者工具”项。
(2)右键单击开发者工具项,在弹出的菜单中选择 “检查/审查元素”项。
如图 6-9 所示,在 Network 面板中可以查看通过网络请求到的资源的详细信息。
3.CURL 常见用法
(1)从浏览器复制 CURL 工具的命令
1)在浏览器页面右键单击,在弹出的菜单中单击“检查”项,这样就看到页面元素。在页面元素上单击右键,在弹出菜单中依次单击“Copy"→“copy as curl” 项,即可把请求内容转化为 CURL 命令。
2)将 CURL 命令复制在 gitbash 或 bash 上并运行命令,则会看到返回的信息。
3)对上面的 CURL 命令进行细化,加入-v 参数可以打印更详细的内容,用 2>&1 将标准错误重定向到标准输出,发送此命令将得到细化后的内容。
细化后的命令如下:
curl 'https://home.testing-studio.com/' -H \
'authority: home.testing-studion.com' -H 'pargma: no-cache'\
-H 'cache-control: no-cache' -H 'upgrde-insecure-requests: 1'\
-H 'user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_0)
AppleWebKit/537.36(KHTML,like Gecko)\
Chrome/80.0.3987.116 Safari/537.36'\
-H 'sec-fetch-dest: document'\
-H 'accept: text/html,application/xhtml+xml,\
application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,\
application/signed-exchange;v=b3;q=0.9'\
-H 'sec-fetch-site: none' -H 'sec-fetch-mode: navigate'\
-H 'sec-fetch-user: ?1'\
-H 'accept-language: en,zh-CN;q=0.9,zh=0.8'\
--compressed -v 2>&1
复制代码
(2)其他常用命令
发起 GET 请求:
curl "https://httpbin.testing-studio.com/get" -H "accept: application/json"
复制代码
发起 POST 请求
curl -X POST "https://httpbin.testing-studio.com/post" -H \
"accept : application/json"
复制代码
Proxy 的使用
curl -X 'http://127.0.0.1:8080' "https://httpbin.testing_studio.com/get"
复制代码
CURL 工具的命令常用参数(见表 6-3)
4.CURL 实战演练
下面通过几个小时的实战演练示例,了解 CURL 工具的命令及一些常用参数的用法。
(1)篡改请求头信息,将 User-Agent 改为了 testing-studio。
curl -H "User-Agent:testing-studio" "http://www.baidu.com" -v
复制代码
上述命令时把请求中的 User-Agent 改为了 testing-studio,结果如下所示。
* Trying 14.215.177.39...
* TCP_NODELAY set
* Connected to www.baidu.com(14.215.177.39) port 80(#0)
> GET / HTTP/1.1
>Host: www.baidu.com
>Accept:*/*
>User-Agent:testing-studio
复制代码
(2)在企业微信中通过 CURL 工具的命令创建标签,这是一个 POST 请求,通过--data 参数传递 tagname 和 tagid。
# token自定义生成
curl -H "Content-Type:application/json" -X POST \
--data '{"tagname":"hogwarts","tagid":13}'\
https://qyapi.weixin.qq.com/cgi-bin/tag/create?access_token = $token
复制代码
(3)认证,通过 PUT 上传到 ElasticSearch,使用--user 进行用户认证。
# ES_HOST index id content均为变量,需替换
curl -X PUT "$ES_HOST/$index/_doc/$id?pretty"\
--user username:password \
-H 'Content-Type: application/json'\
-d "$content"
复制代码
搜索微信公众号:TestingStudio 霍格沃兹的干货都很硬核
评论