13个稳定版本
2.0.0 | 2024年4月17日 |
---|---|
1.6.1 | 2023年4月7日 |
1.6.0 | 2022年1月21日 |
1.5.2 | 2021年9月2日 |
0.1.8 | 2020年7月7日 |
#108 在 #环境变量
26 每月下载量
被 2 crates 使用
135KB
3.5K SLoC
:imagesdir: doc ifdef::env-github[] :imagesdir: https://raw.githubusercontent.com/Leopard2A5/fhttp/master/doc endif::[]
:toc
这是什么?
基于文件的命令行http客户端。
FHTTP不是curl的替代品。它是一个开发者工具,用于发送http请求并将它们作为文件存储,通常与接受http请求的应用程序一起存储在源代码库中。它受到了Postman、Insomnia和IntelliJ http客户端等工具的启发。
|=== |特性 |CUrl |FHTTP |Postman |Insomnia |IntelliJ
|GUI |✕ |✕ |✓ |✓ |✕ |请求集合 |✕* |✓ |✓ |✓ |✓ |版本控制 |✕* |✓ |✕ |✕ |✓ |脚本化 |✓ |✓ |✕ |✕ |✕ |环境变量 |✓ |✓ |✕ |✕ |✓ |配置文件 |✕ |✓ |✓ |✓ |✕ |Pass 密码 |✕* |✓ |✕ |✕ |✕ |一次性运行多个请求 |✕ |✓ |✓ |✕ |✕ |共享集合 |✕* |✓ |✓** |✕ |✓ |完整JavaScript响应处理 |✕ |✕ |✓ |✕ |✓ |插件 |✕ |✕ |✕ |✓ |✕ |GraphQL模式自动完成 |✕ |✕ |✕ |✓ |✕
|=== $$*$$ 如果您使用shell脚本与CUrl一起使用,则可用
$$**$$ 需要账户
安装
安装FHTTP有多种方式
- homebrew . 运行
brew tap Leopard2A5/fhttp && brew install fhttp
- 通过cargo . 运行
cargo install fhttp
(注意:在ubuntu上,您需要apt软件包build-essential
,pkg-config
和libssl-dev
) - 手动 . 下载最新版本 此处 . 重命名下载的文件? . 使文件可执行 . 确保它在您的PATH中
Linux用户:如果您在
加载共享库时遇到错误:libssl.so.1.0.0:无法打开共享对象文件:没有这样的文件或目录
您需要安装 libssl1.0.0: sudo apt-get install libssl1.0.0
功能
- 在 *.http 文件中简单编写一个请求
- 将请求集合直接保存到您的项目仓库中
- 使用配置文件轻松切换环境
- 在请求中解析变量
- 解析存储在 pass 中的机密
- 在请求之间添加依赖关系
- 支持 graphql 请求
- 多部分文件上传
- 导出到 cURL 命令
请求文件的解剖结构
HTTP 格式
请求文件看起来像这样:[source]
METHOD URL
HEADERS?
BODY?
RESPONSE_HANDLER?
必需的部分只有方法(get、post、patch、...)和 URL。您可以使用 #
前缀来忽略该行。
示例请求:[source]
POST https://oauth2tokenendpoint
content-type: application/json; charset=UTF-8
{
"client_id": "foo",
"client_secret": "bar"
}
> {%
json $.access_token
%}
JSON 和 YAML
从版本 1.6 开始,FHTTP 支持在 json 和 yaml 文件格式中编写请求。这些格式的优点是它们是众所周知的,并且允许您以更高的控制创建多部分请求。它们也是 FHTTP 中在多部分请求中混合文件部分和表单数据的唯一方法。它们的格式和结构是相同的。
由于 JSON 的冗长性和 YAML 改进的多行字符串处理功能,推荐使用 YAML 格式。
.Graphql 请求
method: post
url: https://127.0.0.1/graphql
headers:
authorization: Bearer ${request("token.http")}
content-type: application/json
body: |
{
"query": "query($series: String!) { characters(series: $series) { name } }",
"variables": {
"series": "Breaking Bad"
}
}
response_handler:
json: "$.data.characters"
.多部分 JSON 请求
{
"method": "post",
"url": "https://127.0.0.1/upload",
"body": [
{
"name": "metadata",
"text": "{ \"foo\": \"bar\" }",
"mime": "application/json"
},
{
"name": "file",
"filepath": "image.png"
}
]
}
与 *.http 文件一样,方法和 URL 是必需的,而头、正文和 response_handler 是可选字段。
请注意,json 和 yaml 格式不像 *.gql.http 请求那样有 graphQL 便利函数。
body 属性可以是纯字符串或对象列表以创建多部分请求。每个对象需要一个 name
以及一个 text
或 filepath
。您可以可选地通过 mime
属性强制该部分的 content-type。
输出
FHTTP 方便地将日志消息打印到 stderr,并将响应正文打印到 stdout。例如
>fhttp get-实体.http
[source]
> fhttp request.http
POST https://auth-server/token... 200 OK
GET https://server/entities... 200 OK
{
"payload": 123
}
在这个例子中,get-entities.http
依赖于另一个请求以获取认证令牌,该令牌先执行。然后 FHTTP 使用来自 token.http
的数据预处理 get-entities.http
,并执行它,将结果打印到 stdout。
您可以通过传递 -P
或 --print-paths
标志来告诉 FHTTP 打印已执行请求文件的路径,而不是方法和 URL,这在与将多个查询和突变组合在单个路径(/graphql)下的 GraphQL 服务器一起工作时尤其有用。
详细选项
通过增加详细程度,您可以告诉 FHTTP 同时记录 pass 密钥的使用。如果 FHTTP 似乎很慢,这可能很有用,因为 pass 查找可能需要一些时间。
它是如何工作的?
当您调用 FHTTP 时,以下将发生
- 查找配置文件,加载默认配置文件,加载请求的配置文件,如果有的话
- 对于每个给定的请求,查找引用的请求,找到最佳执行顺序
- 对于每个请求,解析变量,插入依赖结果,发送请求,如果有的话,应用响应处理器,保存结果,打印结果,除非此请求是依赖项,并且在调用 FHTTP 时用户没有明确指定
请求预处理
您可以在请求文件中使用表达式。表达式的形式为 ${expression}
。下表概述了当前支持的功能。
预处理表达式 |=== | 表达式 | 描述 | 可用位置
| ${env(NAME)}
| 插入环境变量 NAME,或具有该名称的配置文件变量。如果找不到变量,FHTTP 将提示您输入,除非您已激活 --no-prompt
选项。 | 方法、URL、头部、正文
| ${env(NAME, "default")}
| 插入环境变量 NAME,或者如果没有设置环境变量,则插入给定的默认值。 | 方法、URL、头部、正文
| ${randomInt(lower, upper)}
| 插入一个随机整数。下限和上限是可选的;如果您想指定上限,则必须提供下限。 | 方法、URL、头部、正文
| ${uuid()}
| 插入随机生成的 UUID。 | 方法、URL、头部、正文
| ${request("PATH")}
| 插入由 PATH 指定的请求文件的后期处理正文。PATH 可以是绝对路径,也可以是相对于包含 request(...)
表达式的文件的位置的相对路径。 | 方法、URL、头部、正文
| ${include("PATH")}
| 插入由 PATH 指定的文件的内容。FHTTP 在包含文件时会移除单个尾随换行符。
您可以在包含的文件中使用所有表达式,包括 include
本身,这在处理 GraphQL 片段时特别有用。 | 方法、URL、头部、正文
| ${include_indent("PATH")}
| 与 include
类似,但保留包含文本中调用点的缩进。在 YAML 请求中特别有用,因为常规的 include 可能会使 YAML 文档无效。 | 查看 ${include("PATH")}
| ${file("NAME", "PATH")}
| 仅支持在请求的正文段中。替换除了其他 file(...)
表达式之外的所有正文内容。使用此功能发送多部分请求,上传指定的文件。 | body |===
响应处理器/后处理
每个请求可以包含一个响应处理器表达式。要指定响应处理器,在正文后留一个空行,然后在 > {% handler %}
中放置表达式。例如
[source]
POST http://localhost:8080
{
"foo": "bar"
}
> {%
json $.path.inside.response
%}
.支持的响应处理器 |=== | 处理器 | 描述
| json | 接受一个应用于响应体的 jsonpath 表达式。 | deno | *** Deno 已不再支持。 *** |===
配置文件
您可以创建配置文件以避免每次调用 FHTTP 时手动提供变量。配置文件允许您轻松切换请求的目标环境。默认情况下,如果存在,FHTTP 将使用名为 fhttp-config.json
的文件。一个配置文件可能看起来像这样
[source,json]
{
"default": {
"variables": {
"URL": "https://127.0.0.1:8080"
}
},
"localhost": {
"variables": {
"token": "NO_AUTH"
}
},
"testing": {
"variables": {
"URL": "https://testing.myapp.com",
"CLIENT_ID": "clientid",
"CLIENT_SECRET": {
"pass": "path/to/clientsecret/in/passwordstore"
},
"token": {
"request": "get_token.http"
}
}
}
}
您可以通过使用 --profile-file
选项来更改要使用的配置文件。
您可以使用 --profile
选项来指定要使用的配置文件。如果存在,默认配置文件始终被加载,并且其值将被您指定的任何其他配置文件覆盖。
配置文件中的变量可以有不同的形式
.配置变量 |=== | 变量 | 描述 | 示例
| 字符串 | 将变量设置为这个字符串。a| [source]
"var": "string"
| 解密密码 | 使用 pass 密码存储解析变量。a|[source,json]
{
"pass": "path/in/pass"
}
| 请求 | 解析请求并使用后处理的响应体作为变量。绝对路径或从配置文件的位置相对于的路径。a| [source,json]
{
"request": "path/to/request/file"
}
|===
GraphQL
GraphQL 请求以 json 格式发送到服务器,所以一个 naive 的 GraphQL 请求文件可能看起来像这样
[source]
POST http://graphqlserver
Content-Type: application/json
{
"query": "query($var1: String!) { foo(var1: $var1) { field1 } }",
"variables": {
"var1": "val1"
}
}
这看起来不太美观,尤其是对于较长的 GraphQL 查询,因为我们需要在 JSON 中转义换行符。然而,FHTTP 直接支持 GraphQL 请求。只需更改文件的扩展名为 *.gql.http 或 *.graphql.http,然后像这样更改即可
[source]
POST http://graphqlserver
query($var1: String!) {
foo(var1: $var1) {
field1
}
}
{
"var1": "val1"
}
FHTTP 自动将内容类型设置为 application/json,转义查询字符串,并用查询和变量构建 JSON 负载。GraphQL 请求也支持预处理表达式的完整范围。响应处理器也支持在 GraphQL 请求中。
命令行标志和选项
.命令行标志 |=== | 短 | 长 | 描述
| -h | --help | 打印帮助屏幕。
| | --no-prompt | 在提示输入之前失败,而不是在缺少环境变量时。
| -P | --print-paths | 打印请求文件路径而不是方法和 URL。
| -c | --curl | 打印 cURL 命令而不是执行请求。仍然执行依赖项,只有命令行上列出的请求作为 cURL 命令导出。秘密将被导出为评估,例如 $(pass secretpath)
。
| -q | --quiet | 抑制日志输出。
| -v | --verbose | 控制日志详细程度。
| -V | --version | 打印应用程序的版本。
|===
命令行选项 |=== | 短 | 长 | 描述
| -p | --profile | 要使用的配置文件名。
默认为 "default"。
可以被环境变量 FHTTP_PROFILE 覆盖。
| -f | --profile-file | 要使用的配置文件路径。
默认为 fhttp-config.json。
可以被环境变量 FHTTP_PROFILE_FILE 覆盖。
| -t | --timeout-ms | 每个请求设置超时时间(毫秒)。
| -o | --out | 将标准输出写入的路径。
将会创建新文件或覆盖现有文件的内容。
|===
依赖
~15–30MB
~488K SLoC