

HTTPie 官方文档中文翻译版
source link: https://keelii.com/2018/09/03/HTTPie/?amp%3Butm_medium=referral
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

HTTPie 是一个命令行 HTTP 客户端。目标是让 CLI 与 Web services 的交互尽可能的更友好。它提供了一个简单的 http
命令,可以让我们用简单自然的表述发送任意 HTTP 请求,并且可以输出带代码高亮的结果。HTTPie 可以使用在测试、调试以及通用的与 HTTP 交互场景
主要功能特性
wget
安装
macOS
在 macOS 系统中推荐使用Homebrew 来安装:
brew install httpie
当然 MacPorts 也是可以的:
port install httpie
Linux
大多数的 Linux 构建版都提供了包管理组件,可以使用他们来安装:
# 基于 Debian Linux 的构建版,比如 Ubuntu apt-get install httpie # 基于 RPM Linux 的构建版 yum install httpie # Arch Linux 系统 pacman -S httpie
Windows 及其它
使用 pip 是一种通用的(可以使用在 Windows, MacOS, Linux …)并且提供最新版本安装包的安装方法
# 确保使用了最新版本的 pip 和 setuptools: pip install --upgrade pip setuptools pip install --upgrade httpie
开发版
最新的开发版本可以直接通过 github 安装
# Homebrew brew install httpie --HEAD # pip pip install --upgrade https://github.com/jkbrzt/httpie/archive/master.tar.gz
Python 版本
虽然兼容 Python 2.6, 2.7 版本的,但是如果可以的话还是建议使用最新版的 Python 3.x 来安装 HTTPie。这将保证一些比较新的功能(比如:)可以开箱即用。Python 3 在 Homebrew 0.9.4 版本以上已经成为了默认的 Python 版本。可以使用 http --debug
来查看 HTTPie 使用的 python 版本
使用
最简单的使用:
http httpie.org
使用语法:
http [flags] [METHOD] URL [ITEM [ITEM]]
也可以使用 http --help
来查看更多使用方法:
例子
自定义 HTTP 方法,HTTP 头和 JSON 数据:
http PUT example.org X-API-Token:123 name=John
表单提交:
http -f POST example.org hello=World
使用一个输出参数 -v
来查看请求信息(默认不显示请求信息):
http -v example.org
使用 Github API 向 issue 发送一条评论(需要授权验证参数):
http -a USERNAME POST https://api.github.com/repos/jkbrzt/httpie/issues/83/comments body='HTTPie is awesome! :heart:'
通过命令行的输入重定向上传文件:
http example.org < file.json
使用 wget
风格下载文件:
http --download example.org/file
使用命令会话对同一 host 进行请求之间的持久通信:
http --session=logged-in -a username:password httpbin.org/get API-Key:123 http --session=logged-in httpbin.org/headers
自定义请求 host 头:
http localhost:8000 Host:example.com
HTTP 方法
HTTP 方法的名称在 URL 参数之前:
http DELETE example.org/todos/7
这看起来就像是原生的 HTTP 请求发送的文本一样:
DELETE /todos/7 HTTP/1.1
请求 URL
HTTPie 唯一必传的一个参数是请求 URL,默认的方案不出意料的是 http://
,可以在请求的时候缺省 - http example.org
是没问题的
Querystring 参数
如果需要在命令行手动构建 URLs,你可能会觉得使用 param==value
添加参数的方式是比较方便的,这样你就不需要担心命令行中转义链接字符串 &
的问题,当然参数中的特殊字符也将被自动转义(除非已经转义过)。用下面的命令搜索 HTTPie logo
可以在 google 图片上结果:
http www.google.com search=='HTTPie logo' tbm==isch GET /?search=HTTPie+logo&tbm=isch HTTP/1.1
localhost 的 URL 缩写
另外,类似 curl
的 localhost 缩写也是支持的。这表示你可以使用 :3000
来代替 http://localhost:3000
, 如果不传入端口号, 80
将会默认被使用
http :/foo GET /foo HTTP/1.1 Host: localhost
http :3000/bar GET /bar HTTP/1.1 Host: localhost:3000
http : GET / HTTP/1.1 Host: localhost
自定义默认的方案
你可以使用 --default-scheme <URL_SCHEME>
参数来指定非 HTTP 的其它协义
alias https='http --default-scheme=https'
请求项
不同的请求项类型提供一种便捷的方法来指定 HTTP 头、简单的 JSON 、表单数据、文件、URL 参数
URL 参数后面紧随的是 键/值
对参数都会被拼装成请求发送。不同类型的 键/值
对分割符号分别是: :
, =
, :=
, @
, =@
, :=@
。用 @
分割的参数表示文件路径
Name:Value
任意的 HTTP 头,比如: X-API-Token:123
URL 参数 name==value
通过分割符 ==
表示一个查询字符串的 键/值
对
数据域 field=value
, [email protected]
请求一个默认会被序列化成 JSON 的数据域,或者表单类型 form-encoded (--form, -f)
纯 JSON 域 field:=json
, field:[email protected]
当需要指定一个或者多数域参数类型 boolean
, number
.. 时非常有用, 比如:meals:=’[“ham”,“spam”]’ or pies:=1,2,3.
Form 表单文件域
仅当传入参数 --form, -f
时有效,比如 screenshot@~/Pictures/img.png
文件内容将会被序列化成 multipart/form-data
发送
数据域不是唯一的指定请求数据的方式,也可以
字符转义规则
可以使用 \
来转义不应该被用于分割符的情况。比如 foo\==bar
会被转义成一个数据键值对(foo= 和 bar)而不是 URL 参数
通常情况需要使用引号包围值,比如 foo='bar baz'
如果有一个域的名字或者 header 以减号开头,你需要把这些参数放在一个特殊符号 --
后面
,这样做是为了和 --arguments
区分开
http httpbin.org/post -- -name-starting-with-dash=foo -Unusual-Header:bar POST /post HTTP/1.1 -Unusual-Header: bar Content-Type: application/json { "-name-starting-with-dash": "value" }
JSON
JSON 是现代 web services 通用规范,HTTPie 也默认遵循了它的 不严格的数据类型
http PUT example.org name=John [email protected] PUT / HTTP/1.1 Accept: application/json, */* Accept-Encoding: gzip, deflate Content-Type: application/json Host: example.org { "name": "John", "email": "[email protected]" }
默认行为
如果你的命令包含了一些请求项数据,它们将默认被序列化成 JSON 对象。HTTPie 会默认自动添加下面两个 header 头,当然这两个头也可以重新传入
Content-Typeapplication/json
Accept
application/json, */*
明确的 JSON
你可以使用命令行参数 --json, -j
明确地设置 Accept
为 application/json
而无需在意发送的数据是什么(这是个快捷方式,也可以使用普通的 header 注解: http
url Accept:'application/json, */*'
),另外,HTTPie 会试着检测 JSON 响应,即使 Content-Type
是不正常的 text/plain
或者未知类型
非字符串的 JSON 域
非字符串类型的 JSON 域使用 :=
分割,这可以允许你嵌入原生纯 JSON
到结果对象,文本和原生的纯 JSNO 文件也可以使用 =@
和 :=G
嵌入
http PUT api.example.com/person/1 \ name=John \ age:=29 married:=false hobbies:='["http", "pies"]' \ # Raw JSON [email protected] \ # Embed text file bookmarks:[email protected] # Embed JSON file PUT /person/1 HTTP/1.1 Accept: application/json, */* Content-Type: application/json Host: api.example.com { "age": 29, "hobbies": [ "http", "pies" ], "description": "John is a nice guy who likes pies.", "married": false, "name": "John", "bookmarks": { "HTTPie": "http://httpie.org", } }
不过请注意,当发送复杂数据的时候,这个例子使用的语法会显得很笨重。在这种情况下将会更合适:
http POST api.example.com/person/1 < person.json
表单
提交表单和发送 JSON 请求很相似,通常情况下唯一的不同是添加额外的 --form, -f
参数,这将确保数据域和 Content-Type
被设置成 application/x-www-form-urlencoded; charset=utf-8
普通的表单
http --form POST api.example.org/person/1 name='John Smith' POST /person/1 HTTP/1.1 Content-Type: application/x-www-form-urlencoded; charset=utf-8 name=John+Smith
文件上传表单
如果有一个文件域,序列化方式和 content type 会是 multipart/form-data
:
http -f POST example.com/jobs name='John Smith' cv@~/Documents/cv.pdf
上面的请求和下面的 HTML 表单发送请求是一样的:
<form enctype="multipart/form-data" method="post" action="http://example.com/jobs"> <input type="text" name="name" /> <input type="file" name="cv" /> </form>
注意 @
用来模拟文件上传域,而 =@
是把文件内容以文本的方式嵌入到数据域的值里面
HTTP 头
可以使用 Header:Value
注解的形式来添加自定义头信息
http example.org User-Agent:Bacon/1.0 'Cookie:valued-visitor=yes;foo=bar' \ X-Foo:Bar Referer:http://httpie.org/ GET / HTTP/1.1 Accept: */* Accept-Encoding: gzip, deflate Cookie: valued-visitor=yes;foo=bar Host: example.org Referer: http://httpie.org/ User-Agent: Bacon/1.0 X-Foo: Bar
默认的请求头
有几个默认的请求头是 HTTPie 设置的
GET / HTTP/1.1 Accept: */* Accept-Encoding: gzip, deflate User-Agent: HTTPie/<version> Host: <taken-from-URL>
空头和重新设置默认头
可以使用 Header:
来取消上面的几个默认头信息
http httpbin.org/headers Accept: User-Agent:
请求中的 Accept
和 User-Agent
头都会被移除
使用 Header;
表示添加一个为空的头信息,注意须使用引号
http -v httpbin.org/headers 'Host;' GET /headers HTTP/1.1 Accept: */* Accept-Encoding: gzip, deflate Connection: keep-alive Host: User-Agent: HTTPie/0.9.9 ...
授权验证
目前支持的验证方案有基础和摘要两种(查看更多),有两种标识来控制验证:
参数 说明--auth, -a
把 用户名:密码
做为键值对参数传入,如果只指定用户名可以使用 -a 用户名
,密码在接下来的提示符中输入,空密码使用 username:
, username:password@hostname
格式的 URL 语法也是支持的,证书通过 -a
参数传入且具有更高的优先级
--auth-type, -A
指定指定身份验证机制。 basic
(默认) 和 digest
两种
Basic 授权
http -a username:password example.org
Digest 授权
http -A digest -a username:password example.org
密码提示
http -a username example.org<Paste>
.netrc
从你的 ~/.netrc
文件授权也可以
cat ~/.netrc machine httpbin.org login httpie password test http httpbin.org/basic-auth/httpie/test HTTP/1.1 200 OK [...]
授权插件
授权机制可以使用安装插件的方式来实现,可以在 Python Package 上面找到更多相关插件
- httpie-api-auth : ApiAuth
- httpie-aws-auth : AWS / Amazon S3
- httpie-edgegrid : EdgeGrid
- httpie-hmac-auth : HMAC
- httpie-jwt-auth : JWTAuth (JSON Web Tokens)
- httpie-negotiate : SPNEGO (GSS Negotiate)
- httpie-ntlm : NTLM (NT LAN Manager)
- httpie-oauth : OAuth
- requests-hawk : Hawk
HTTP 重定向
HTTP 重定向默认不会自动跳转,请求发出后命令行只会显示 第一次 收到的响应
http httpbin.org/redirect/3
按 header 头中的 location 字段值跳转
指定 --follow, -F
参数让 HTTPie 自动跟随 30x
响应头中的 location
字段值进行跳转,并且显示最终的响应内容
http --follow httpbin.org/redirect/3
显示中间的跳转响应
如果你也想看到更多的跳转信息,可以指定 --all
参数
http --follow --all httpbin.org/redirect/3
限制重定向最大次数
改变默认最大 30
次重定向值可以使用 --max-redirects=<limit>
参数
http --follow --all --max-redirects=5 httpbin.org/redirect/3
代理
你可以通过添加参数 --proxy
来指定各自协义(为了防止跨协义的重定向,协义被包含在了参数值中)的代理服务器
http --proxy=http:http://10.10.1.10:3128 --proxy=https:https://10.10.1.10:1080 example.org
添加 basic 授权
http --proxy=http:http://user:[email protected]:3128 example.org
环境变量
也可以通过设置 HTTP_PROXY
和 HTTPS_PROXY
环境变量来配置代理,底层的 request
库也将使用这些代理配置,如果你想指定某些 host 不使用代理,可以通过添加 NO_PROXY
参数来实现
在你的 ~/.bash_profile
文件中(zsh 则在 ~/.zshrc
中)
export HTTP_PROXY=http://10.10.1.10:3128 export HTTPS_PROXY=https://10.10.1.10:1080 export NO_PROXY=localhost,example.com
Socks
要启用 socks 代理支持请使用 pip 安装 requests[socks]
库
pip install -U requests[socks]
用法与其它类型的代理相同:
http --proxy=http:socks5://user:pass@host:port --proxy=https:socks5://user:pass@host:port example.org
HTTPS
服务器 SSL 证书验证
使用参数 --verify=no
可以跳过主机 SSL 验证(默认: yes
)
http --verify=no https://example.org
自定义 CA 包
使用 --verify=<CA_BUNDLE_PATH>
指定 CA 认证包路径
http --cert=client.pem https://example.org
客户端 SSL 证书
使用客户端 SSL 证书进行 SSL 通信,可以用 --cert
参数指定证书文件路径
http --cert=client.pem https://example.org
如果证书中不包含私钥,可以通过 --cert-key
参数指定密钥文件路径
http --cert=client.crt --cert-key=client.key https://example.org
SSL 版本
参数 --ssl=<PROTOCOL>
用来指定你想使用的 SSL 协义版本,默认是 SSL
v2.3
。这将会协商服务端和你安装的 OpenSSL 支持的最高 SSL
协议版本。可用的版本有: ssl2.3
, ssl3
, tls1
, tls1.1
, tls1.2
(实际上可用的协义可能有很多种,这由你安装的 OpenSSL 决定)
# 指定容易受到攻击的 SSL v3 协义与老服务器进行通信 http --ssl=ssl3 https://vulnerable.example.org
服务器名称指示 SNI(Server Name Indication)
如果你的 HTTPie 版本(可以使用 http --debug
查看版本)小于 2.7.9,又需要使用
SNI 与服务器会话。那么你需要安装额外的依赖
pip install --upgrade requests[security]
使用下面的命令测试 SNI 支持
http https://sni.velox.ch
输出参数
HTTPie 默认只输出最终响应信息并且打印(header, body同样),你可以通过下面一些参数控制打印内容:
命令行参数 描述 –headers, -h 仅打印响应头 –body, -b 仅打印响应体 –verbose, -v 打印所有的 HTTP 请求来回内容,这将默认开启--all
参数
使用 --verbose
参数来调试请求或生成文档时是非常有用的
http --verbose PUT httpbin.org/put hello=world PUT /put HTTP/1.1 Accept: application/json, */* Accept-Encoding: gzip, deflate Content-Type: application/json Host: httpbin.org User-Agent: HTTPie/0.2.7dev { "hello": "world" } HTTP/1.1 200 OK Connection: keep-alive Content-Length: 477 Content-Type: application/json Date: Sun, 05 Aug 2012 00:25:23 GMT Server: gunicorn/0.13.4 { […] }
哪部分的 HTTP 请求内容应该打印出来
所有的 HTTP 输出选项都属于更强大的 --print, -p
参数的快捷方式。 --print, -p
接受一个字符串,字符串的每个字母都表示下面的 HTTP 某一部分
H
请求头
B
请求体
h
响应头
b
响应体
打印请求头和响应头:
http --print=Hh PUT httpbin.org/put hello=world
查看中间的请求/响应
使用 --all
参数可以查看 HTTP 通信中的所有信息,中间的 HTTP
通信包括跟随重定向(使用参数 --follow
)和使用 HTTP
摘要授权时第一次未授权的请求(使用参数 --auth=diggest
)
# 包括最终响应之前的所有响应信息 http --all --follow httpbin.org/redirect/3
中间请求/响应默认会使用 --print, -p
参数指定的值格式化,可以使用 --history-print, -P
指定,
参数和 --print, -p
是一样的。但是这只实用于 中间请求
# 中间请求/响应信息使用 H 格式化,最终请求/响应信息使用 Hh 格式化: http -A digest -a foo:bar --all -p Hh -P H httpbin.org/digest-auth/auth/foo/bar
条件化的 body 内容下载
做为一个优化项,响应体在仅作为输出一部分时才会被下载,这和 HEAD
类型的请求类似(除了 HEAD 可以使用在任何 HTTP 请求中)
比如有一个 API 更新后会返回整个资源,但是你只对更新后响应头中的状态码感兴趣:
http --headers PATCH example.org/Really-Huge-Resource name='New Name'
由于我们在上面设置了只打印头信息,当响应头接收完成的时候服务器连接就会被关闭, 带宽和时间不会浪费在下载响应体,你可以不必在意。响应头总是会被下载的无论它是不是输出部分
重定向输入
直接从 stdin
(标准输入)管道传入请求数据是大部分人认为比较好的方法。
这些数据被缓冲而且不需要更多的操作就可以做为请求体被使用,使用管道有下面几个好用的方法:
从一个文件重新定向
http PUT example.com/person/1 X-API-Token:123 < person.json
或者从其它程序的输出
grep '401 Unauthorized' /var/log/httpd/error_log | http POST example.org/intruders
当然也可以使用 echo
命令来传简单数据
echo '{"name": "John"}' | http PATCH example.com/person/1 X-API-Token:123
甚至可以使用 web services
http GET https://api.github.com/repos/jkbrzt/httpie | http POST httpbin.org/post
也可以使用 cat
命令来输入多行文本
cat | http POST example.com <paste> ^D
cat | http POST example.com/todos Content-Type:text/plain - buy milk - call parents ^D
在 macOS 中可以使用 pbpaste
命令把剪贴板中的内容做为数据发送
pbpaste | http PUT example.com
通过 stdin
传递数据的方式 不能
和指定数据域的方式混合使用
echo 'data' | http POST example.org more=data # 不可以
从一个文件中取请求数据
指定文件路径( @/path/to/file
)方式可以替代上面使用 stdin
的方式
这个方法有个优点, Content-Type
可以根据提供的文件扩展名自动设置成对应的。比如下面的请求会被设置头 Content-Type: application/xml
http PUT httpbin.org/put @/data/file.xml
命令行输出
HTTPie 默认会做一些事情,目的是为了让命令行输出内容有更高的可读性
颜色和格式化
语法高亮会应用在 HTTP 请求的 headers 和 body 里面。如果你不喜欢默认的配色方案,可以使用 --style
参数自定义(使用 http --help
命令查看更多选项)
还有下面几个格式化规则会被使用:
- HTTP 头会按名称排序
- JSON 数据会有缩进,并且按 key 名排序,unicode 序列会被转换成实际字符
下面这些参数可以用在处理输出结果中:
命令行参数 描述 –pretty=all 应用颜色和格式化,默认 –pretty=colors 仅应用颜色 –pretty=format 仅应用格式化 –pretty=none 不使用颜色和格式化,重定向时默认使用二进制数据
二进制数据在命令行中会被禁止,这会使处理响应返回的二进制数据变得更安全,重定向时也禁止二进制数据,但是会被装饰输出。一旦当我们知道响应体是二进制数据时,连接会关闭
http example.org/Movie.mov
你几乎可以立即看见下面的提示:
HTTP/1.1 200 OK Accept-Ranges: bytes Content-Encoding: gzip Content-Type: video/quicktime Transfer-Encoding: chunked +-----------------------------------------+ | NOTE: binary data not shown in terminal | +-----------------------------------------+
重定向输出
与命令行输出相比,重定向输出使用了不同的默认值,不同之处在于:
--pretty
原因是为了把 HTTPie 的结果直接 piping 到其它程序,并且使下载文件不需要额外的参数标识。多数情况下输出重定向时只有响应体有意义
下载一个文件:
http example.org/Movie.mov > Movie.mov
下载 Octocat 图片,使用 ImageMagick 修改大小,上传到其它地方:
http octodex.github.com/images/original.jpg | convert - -resize 25% - | http example.org/Octocats
强制使用格式化与颜色,在 less
的分页中显示请求和响应
http --pretty=all --verbose example.org | less -R
-R
标识告诉 less
命令解析 HTTPie 输出中的颜色序列
你可以使用下面的 bash 函数代码建立一个调用 HTTPie 分页格式化且高亮输出的快捷方式:
function httpless { # `httpless example.org' http --pretty=all --print=hb "$@" | less -R; }
下载模式
HTTPie 具有下载模式,这和 wget
命令类似
使用 --download, -d
标识启用,响应头会打印到命令行,下载响应体的进度条也会显示
http --download https://github.com/jkbrzt/httpie/archive/master.tar.gz HTTP/1.1 200 OK Content-Disposition: attachment; filename=httpie-master.tar.gz Content-Length: 257336 Content-Type: application/x-gzip Downloading 251.30 kB to "httpie-master.tar.gz" Done. 251.30 kB in 2.73862s (91.76 kB/s)
下载文件的文件名
如果没有指定参数 --output, -o
,文件名将由 Content-Disposition
决定,或者通过
URL 及其 Content-Type
,如果名字已占用,HTTPie 会添加唯一后缀
下载的同时 piping
即使响应头和进度状态显示在命令行中,你仍然可以将响应重定向到其它的程序
http -d https://github.com/jkbrzt/httpie/archive/master.tar.gz | tar zxf -
恢复下载
如果指定 --output, -o
,你可以 --continue, -c
恢复部分下载。不过仅当服务器支持 Range
请求而且响应返回 206 Partial Content
才可以,如果服务器不支持这个功能,那就只会下载整个文件
http -dco file.zip example.org/file
其它注意事项
-
--download
仅更改响应正文的处理方式 -
仍然可以使用自定义 header 头、使用 session 会话,
--verbose, -v
等 -
--download
意味着启用--follow
-
如果文件没有被完全下载完,HTTPie 将会返回错误状态码
1
并退出 -
Accept-Encoding
不能和--download
一起使用
流式响应
响应体会被以块的形式下载和打印,这使程序在不使用大量内存情况下进行流式传输和下载,然而如果使用颜色和格式化参数, 整个 响应体会被缓冲,然后立即处理
禁用缓冲
可以使用 --stream, -S
进行下面的操作:
tail -f
示例
修饰过的流响应
http --stream -f -a YOUR-TWITTER-NAME https://stream.twitter.com/1/statuses/filter.json track='Justin Bieber'
像 tail -f
一样小块的流输出
http --stream -f -a YOUR-TWITTER-NAME https://stream.twitter.com/1/statuses/filter.json track=Apple \ | while read tweet; do echo "$tweet" | http POST example.org/tweets ; done
会话
默认情况下,同一个 host 每个 HTTPie 发出的请求完全独立
然而,HTTPie 支持使用 --session=SESSION_NAME_OR_PATH
参数进行持久会话。在同一个 host 的会话中,自定义 header(除了以 Content-
和 If-
开头)、authorization、cookies(手动指定或者服务器发送) 会持续保存
# 创建一个新会话 http --session=/tmp/session.json example.org API-Token:123 # 复制用已存在的会话 API-Token 会自动设置 http --session=/tmp/session.json example.org
所有的会话数据都会被存储成纯文本,这表示会话文件可以使用编辑器手动添加或者修改——其实就是 JSON 数据
具名会话
每个 host 都可以建一个或者多个会话,比如:下面的命令将为 host 是 example.org
的请求建一个名为 name1
的会话:
http --session=user1 -a user1:password example.org X-Foo:Bar
从现在起,你就通过名字来选择会话,当你选择使用一个会话时,之前用过的授权、HTTP 头都会被自动添加:
http --session=user1 example.org
创建或者重用不同的会话,只需要指定不同的名字即可:
http --session=user2 -a user2:password example.org X-Bar:Foo
具名会话将被以 JSON 的数据格式存储在 ~/.httpie/sessions/<host>/<name>.json
下面(windows下则是 %APPDATA%\httpie\sessions\<host>\<name>.json
)
匿名会话
不同与具名会话,你也可以直接使用一个文件路径来指定会话文件的存储地址,这也可以在不同的 host 间复用会话:
http --session=/tmp/session.json example.org http --session=/tmp/session.json admin.example.org http --session=~/.httpie/sessions/another.example.org/test.json example.org http --session-read-only=/tmp/session.json example.org
只读会话
如果复用一个会话又不想更新会话信息,可以通过指定 --session-read-only=SESSION_NAME_OR_PATH
来实现
配置
HTTPie 使用了一个简单的 JSON 配置文件
配置文件路径
默认的配置文件路径在 ~/.httpie/config.json
(window 在 %APPDATA%\httpie\config.json
),配置文件的路径也可以通过修改环境变量 HTTPIE_CONFIG_DIR
来更改,可以使用 http --debug
命令查看当前配置文件路径
可配置的参数
JSON 配置文件包含以下的键:
default_options
参数默认值数组(默认为空),数组里面的参数会被应用于每次 HTTPie 的调用
比如说,你可以使用这个选项改变默认的样式和输出参数: "default_options": ["--style=fruity", "--body"]
,另外一个常用的默认参数是 "--session=default"
,这会让 HTTPie 总是使用会话(名称为default)。也可以使用 --form
改变默认 不严格的
JSON 类型为 form 类型
__meta__
HTTPie 自动存储了一些它自己的元数据,不要动它
取消之前指定的参数
配置文件中的参数和其它任何指定参数的方法,都可以使用 --no-OPTION
参数来取消,比如: --no-style
或者 --no-session
脚本
当你在 shell 脚本中使用 HTTPie 的时候, --check-status
标识会比较好用。这个标识将告知 HTTPie 如果响应状态码是 3xx
, 4xx
, 5xx
时程序将退出并显示对应的错误码 3
(除非 --follow
参数被指定), 4
, 5
#!/bin/bash if http --check-status --ignore-stdin --timeout=2.5 HEAD example.org/health &> /dev/null; then echo 'OK!' else case $? in 2) echo 'Request timed out!' ;; 3) echo 'Unexpected HTTP 3xx Redirection!' ;; 4) echo 'HTTP 4xx Client Error!' ;; 5) echo 'HTTP 5xx Server Error!' ;; 6) echo 'Exceeded --max-redirects=<n> redirects!' ;; *) echo 'Other Error!' ;; esac fi
最佳实践
在非交互式调用的情况下通常不希望使用 stdin
的默认行为,可以使用 --ignore-stdin
参数来禁止它
如果没有这个选项,HTTPie 可能会挂起,这是一个常见的问题。发生的场景可能是——例如从定时任务中调用HTTPie时, stdin
未连接到终端。因此,重定向输入的规则适用,即 HTTPie 开始读取它,希望请求体将被传递。由于没有数据也没有 EOF,它会被卡住。因此,除非你将一些数据传递给 HTTPie,否则应在脚本中使用此标志
当然使用 --timeout
参数手动设置(默认 30 秒)延迟时间是个比较好的做法
元信息
接口设计
命令行参数的设计与通过网络发送 HTTP 请求的过程密切相关。这使得 HTTPie 的命令更容易记忆和阅读。有时你甚至可以把原生的 HTTP 请求串连到一行就很自然的形成了 HTTPie 的命令行参数。例如 对比下面这个原生 HTTP 请求:
POST /collection HTTP/1.1 X-API-Key: 123 User-Agent: Bacon/1.0 Content-Type: application/x-www-form-urlencoded name=value&name2=value2
和使用 HTTPie 命令发送同样的参数:
http -f POST example.org/collection \ X-API-Key:123 \ User-Agent:Bacon/1.0 \ name=value \ name2=value2
注意他们两者的顺序和参数都非常相似,并且只有一小部分命令用于控制 HTTPie( -f
表示让 HTTPie 发送一个 from 请求),并且不直接对应于请求的任何部分
两种模式: --pretty=all
(命令行中默认)、 --pretty=none
(重定向输出时默认),对交互式使用和脚本调用都比较友好,HTTPie 在这过程中作为通用的 HTTP 客户端
由于 HTTPie 还在频繁的开发中,现有的一些命令行参数在最终版 1.0
发布之前可能会有一些微小的调整。这些调整都会在里面记录
用户支持
你可以通过下面的一些途径找到帮助支持
- GitHub issues
- Our Gitter chat room
- StackOverflow
- Twitter @clihttp ,也可以直接 @jkbrzt
相关项目
依赖
HTTPie 底层使用了两个特别棒的库:
Requests — Python HTTP 库 Pygments — Python 代码高亮
HTTPie 的朋友
HTTPie 可以和下面两个好友愉快地玩耍:
Recommend
-
116
Python - @summer_charlie - 一直以来 Python 中文社区
-
22
Thread 这一篇文章主要记录 AsyncTask 相关的知识点。 大部分内容来自官方文档,
-
14
Truffle 翻译说明及概述¶ 本文档是基于 Truffle 官方最新文档 由 深入浅出区块链 社区...
-
17
极客学院团队出品 · 更新于 2018-11-28 11:00:43 TensorFlow 官方文档中文版 你正在阅读的项目可能会比 And...
-
7
欢迎参与 Flask 文档中文翻译李辉greyli.com我在上周开始策划 Flask 文档翻译的事,制...
-
7
V2EX › 程序员 Vue 中文文档:在不经 Vue 官方翻译团队认可的情况下布署是否违反 MIT 协议?
-
7
Dapr 官方文档中文翻译 v1.5 版本正式发布 2022-03-20 4 分钟阅读时长 经过 Dapr 中国社...
-
6
Dapr 官方文档中文翻译 v1.5 版本正式发布 作者:敖小剑 - Dapr Approve...
-
8
Mocha.js官方文档翻译 —— 简单、灵活、有趣Mocha.js官方文档翻译 —— 简单、灵活、有趣Awey0.9932016.10.08...
-
7
mocha中文文档 这个是对mocha文档的翻译,都是我一个字一个字敲出来的。水平有限,激情无限,欢迎大家批评指正。 使用npm全局安装:
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK