首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >IntelliJ中基于文本的HTTP客户端

IntelliJ中基于文本的HTTP客户端

作者头像
FunTester
发布2020-09-27 11:06:39
2K0
发布2020-09-27 11:06:39
举报
文章被收录于专栏:FunTesterFunTester

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"
  }
}

这定义了两个环境:devonline。两种环境都使用不同的值定义host变量。

运行请求时,我们现在可以选择所需的环境:

团队共享

基于文本的简单请求定义使您可以轻松地与团队共享。您甚至可以将请求文件检入版本控制系统。当然,您不希望签入执行请求可能需要的密码或API密钥。IntelliJ通过单独的私有环境文件(http-client.private.env.json)支持此功能。与前面的环境示例一样,我们可以使用此文件来定义变量。

例如:

{
  "dev": {
    "api-key": "S3DKLJ56698CR3T"
  }
}

为了确保安全性,我们可以从版本控制系统中明确排除此文件。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-09-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FunTester 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 入门
  • 使用变量
  • 团队共享
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档