IntelliJ
提供了一个纯基于文本的HTTP客户端。尽管一开始听起来可能很奇怪,但事实证明这是一个非常有用的功能。
入门
首先,我们需要创建一个名称以.http
或.rest
结尾的文件。例如FunTester.http
。
要发出简单的GET请求,我们必须在新创建的文件中写下该请求。
例如:
GET https://api.muxiaoguo.cn/api/dujitang
IntelliJ
现在在该行旁边添加了一个小的Run-Icon,它可以执行请求。
- 响应结果:
GET https://api.muxiaoguo.cn/api/dujitang
HTTP/1.1 200 OK
Server: nginx
Date: Tue, 22 Sep 2020 08:17:55 GMT
Content-Type: text/html; charset=utf-8
Transfer-Encoding: chunked
Connection: keep-alive
Vary: Accept-Encoding
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate
Pragma: no-cache
Strict-Transport-Security: max-age=31536000
{"code":"200","msg":"success","data":{"comment":"你以为有钱人很快乐吗?他们的快乐你根本想象不到!"}}
Response code: 200 (OK); Time: 146ms; Content length: 76 bytes
Cannot preserve cookies, cookie storage file is included in ignored list:
> /Users/fv/Documents/workspace/fun/.idea/httpRequests/http-client.cookies
- 如果要添加
JSON
参数的请求头,只需添加Content-Type
标头和请求正文:
GET https://api.muxiaoguo.cn/api/dujitang
cookie: PHPSESSID=e78ldgop6jub72kp636vqcsj6l
user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.102 Safari/537.36
Content-Type: application/json
{
"aa": "FunTester",
"ss": "ok"
}
- 同一文件中的多个请求需要使用###分隔。例如:
GET https://api.muxiaoguo.cn/api/dujitang
cookie: PHPSESSID=e78ldgop6jub72kp636vqcsj6l
user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.102 Safari/537.36
###
GET https://api.muxiaoguo.cn/api/dujitang
cookie: PHPSESSID=e78ldgop6jub72kp636vqcsj6l
user-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.102 Safari/537.36
Content-Type: application/json
{
"aa": "FunTester",
"ss": "ok"
}
使用变量
使用{{..}}
语法,我们可以向请求中添加变量。也许我们想针对不同的环境发出相同的请求。为此,我们可以使用host
变量更新请求:
GET http://{{host}}/products
接下来,我们需要定义{{host}}
变量。为此,我们创建一个http-client.env.json
文件并添加以下内容:
{
"development": {
"host": "http://localhost:8080"
},
"production": {
"host": "http://my-cool-api.com"
}
}
这定义了两个环境:dev
和online
。两种环境都使用不同的值定义host
变量。
运行请求时,我们现在可以选择所需的环境:
团队共享
基于文本的简单请求定义使您可以轻松地与团队共享。您甚至可以将请求文件检入版本控制系统。当然,您不希望签入执行请求可能需要的密码或API密钥。IntelliJ
通过单独的私有环境文件(http-client.private.env.json)支持此功能。与前面的环境示例一样,我们可以使用此文件来定义变量。
例如:
{
"dev": {
"api-key": "S3DKLJ56698CR3T"
}
}
为了确保安全性,我们可以从版本控制系统中明确排除此文件。
公众号FunTester首发,原创分享爱好者,腾讯云和掘金社区首页推荐,知乎七级原创作者,欢迎关注、交流,禁止第三方擅自转载。