大家好,我是狂师!
今天给大家推荐一款开源的HTTP测试工具:Hurl,
相比curl、wget 功能更强大,且更容易上手、很适用新手使用。
1、项目介绍 Hurl
是一个使用Rust
语言开发的命令行工具,它允许用户运行以简单纯文本格式定义的HTTP请求。这个工具不仅适用于获取数据,还非常适合用于测试HTTP会话和API。
项目地址:
https://github.com/Orange-OpenSource/hurl
Hurl的主要特性和用途包括但不限:
请求发送与捕获 :Hurl可以发送HTTP请求,并捕获响应中的值。这使得用户可以方便地执行各种HTTP操作,并收集所需的响应数据。查询与评估 :Hurl支持对标头和正文响应进行查询和评估。用户可以使用XPath和JSONPath等多种查询方式,以满足不同的测试需求。链式调用 :Hurl支持多个请求的链式调用,这使得用户可以方便地构建复杂的测试用例,从而更全面地测试HTTP会话或API。集成与报告 :Hurl易于集成到CI/CD(持续集成/持续部署)流程中,支持生成多种格式的报告,如文本报告、JUnit报告和HTML报告,这有助于用户分析和理解测试结果。适用于多种场景 :Hurl不仅适用于REST/JSON API的测试,还适用于HTML内容、GraphQL以及SOAP API等多种场景。总的来说 ,Hurl是一个非常灵活且功能丰富的命令行工具,它不仅可以发送HTTP请求,还可以将这些请求链接在一起,形成请求链。这个特性使得Hurl在模拟复杂的用户交互场景时特别有用。此外,Hurl还能够捕获请求中的特定值,并对响应头部和响应正文中的信息进行查询和评估。无论是对于初学者还是经验丰富的测试人员,Hurl都是一个值得考虑的选择。
2、不同平台安装下载 Hurl作为一个功能强大的命令行HTTP请求工具,其安装步骤在不同的操作系统上会有所不同。以下是针对各个平台的安装操作步骤:
Mac用户 :可以通过Homebrew来安装Hurl。在终端中输入命令,按照提示完成安装过程。brew install hurl
Windows用户 :可以访问Hurl的GitHub发布页面,下载最新版本的安装包,然后按照提示进行安装。https://github.com/Orange-OpenSource/hurl/releases
Linux用户 :可以使用包管理器来安装Hurl。例如,在基于Debian的系统上,可以使用apt-get install hurl
命令来安装。3、Hurl使用 1、GET请求
# Get home: GET https:// HTTP 200 [Captures] csrf_token: xpath "string(//meta[@name='_csrf_token']/@content)" # Do login! POST https:///login?user=toto&password=1234 X-CSRF-TOKEN: {{csrf_token}} HTTP 302
2、POST请求
POST https:///api/tests { "id" : "4568" , "evaluate" : true } HTTP 200 [Asserts] header "X-Frame-Options" == "SAMEORIGIN" jsonpath "$.status" == "RUNNING" # Check the status code jsonpath "$.tests" count == 25 # Check the number of items jsonpath "$.id" matches /\d{4}/ # Check the format of the id
Hurl虽是一个命令行工具,但Hurl的主要使用方式是通过编写Hurl文件,这些文件包含了要发送的HTTP请求的定义。然后,用户可以通过Hurl命令行工具来运行这些文件,发送请求并获取响应。
示例一:发送GET请求并输出响应
1、创建Hurl文件内容 (example1.hurl)
GET https://api./data
2、执行命令行
hurl example1.hurl
example1.hurl 是包含HTTP请求的Hurl文件。执行此命令后,Hurl会发送一个GET请求到https://api./data
,并在终端输出服务器的响应。
示例二:发送POST请求并携带JSON数据
1、创建Hurl文件内容 (example2.hurl)
POST https://api./create Content-Type: application/json { "name" : "John Doe" , "age" : 30 }
2、执行命令行
hurl example2.hurl
执行命令后,Hurl会发送POST请求到https://api./create
,并在请求体中携带JSON数据。
示例三:使用变量和链式请求
1、创建Hurl文件内容 (example3.hurl)
GET https://api./user/123 # 捕获响应中的token {{token}} = response.headers.get("X-Auth-Token" ) GET https://api./data Authorization: Bearer {{token}}
2、执行命令行
hurl example3.hurl
3、执行解释:
第一个GET请求用于获取用户的认证token。{{token}} = response.headers.get("X-Auth-Token") 这行代码捕获响应头中的X-Auth-Token值,并将其存储在token变量中。 第二个GET请求使用了前面捕获的token变量作为Authorization头的值,用于后续的认证。 执行命令后,Hurl会按照顺序执行两个请求,并在第二个请求中使用第一个请求的响应数据。 示例四:包含断言和隐式验证
1、创建Hurl文件内容 (example4.hurl)
GET https://api./status # 隐式验证:检查状态码是否为200 HTTP/1.1 200 # 显式断言:检查响应体是否包含特定文本 assert contains(response.body, "OK" )
2、执行命令行:hurl example4.hurl
3、执行解释
发送GET请求到https://api./status。 隐式验证是通过在Hurl文件中直接指定期望的HTTP状态码(这里是200)来完成的。如果服务器的响应状态码与指定的不同,Hurl会报错。 显式断言使用assert关键字来检查响应体是否包含"OK"文本。如果不包含,测试将失败。 这些示例展示了Hurl的基本用法和一些高级特性,如变量捕获、链式请求和断言验证。
你可以根据自己的需求,结合Hurl的文档和这些示例,构建更复杂的HTTP测试场景。