前言

接口调试是每个软件开发从业者必不可少的一项技能,一个项目的的完成,可能接口测试调试的时间比真正开发写代码的时间还要多,几乎是每个开发的日常工作项。所谓工欲善其事必先利其器,在没有尝到 IDEA REST 真香之前,postman(chrome 的一款插件)确实是一个非常不错的选择,具有完备的 REST Client 功能和请求历史记录功能。但是当使用了 IDEA REST 之后,postman 就可以丢了,因为,IDEA REST Client 具有 postman 的所有功能,而且还有 postman 没有的功能,继续往下看。

从 postman 到 IDEA REST Client

真香定律的原因有如下几个:

  1. 首先 postman 的所有功能 IDEA REST Client 都具备了,如 REST Client 控制台和历史请求记录
  2. 其次如果能够在一个生产工具里完成开发和调试的事情,干嘛要切换到另一个工具呢
  3. 然后 IDEA REST Client 还支持环境配置区分的功能,以及接口响应断言和脚本化处理的能力
  4. IDEA REST Client 的请求配置可以用文件配置描述,所以可以跟随项目和项目成员共享

IDEA REST Client 控制台

从顶层工具栏依次 Tools -> HTTP Client -> Test RESTFUL Web Service 打开后,IDEA REST Client 控制台的界面如下样式:

可以看到,这个控制台展示的功能区和 postman 已经没什么差别了,包括请求方式,请求参数和请求头的填充都已经包含了,特别说明下的是,如果请求的方式是 Authorization :Basic 这种方式认证的话,可以点击下图所示的按钮,会弹出填充用户名和密码的窗口出来,填完后会自动补充到 Authorization 的 header 里面去

历史请求记录

IntelliJ IDEA 自动将最近执行的 50 个请求保存到 http-requests-log.http 文件中,该文件存储在项目的.idea / httpRequests / 目录下。使用请求历史记录,您可以快速导航到特定响应并再次发出请求。文件内容大如下图所示,再次发出请求只要点击那个运行按钮即可。如果从请求历史记录再次发出请求,则其执行信息和响应输出的链接将添加到请求历史记录文件的顶部。

构建 HTTP 请求脚本

上面的历史记录就是一个完整的 IDEA REST Client 请求脚本,如果你是从控制台触发的,那么可以直接复制历史请求记录的文件放到项目里作为 HTTP 请求的脚本,给其他成员共享,如果不是,也可以直接新建一个. http 或者. rest 结尾的文件,IDEA 会自动识别为 HTTP 请求脚本。

语法部分

### 演示POST请求
POST {{baseUrl}}}get?show_env=1
Accept: application/json{"name":"a"
}
### 演示GET请求GET {{baseUrl}}}/post
Content-Type: application/x-www-form-urlencodedid=999&value=content

首先通过 ### 三个井号键来分开每个请求体,然后请求 url 和 header 参数是紧紧挨着的,请求参数不管是 POST 的 body 传参还是 GET 的 parameter 传参,都是要换行的

环境区分

细心的你可能发现了上面示例的代码,没有真实的请求地址,取而代之的,是一个 {{baseUrl}} 的占位符,这个就是 IDEA REST Client 真香的地方,支持从指定的配置文件中获取到环境相关的配置参数,不仅 baseUrl 可以通过占位符替换,一些请求的参数如果和接口环境相关的都可以通过配置文件来区分。

首先在. http 的脚本同目录下创建一个名为 http-client.private.env.json 的文件,然后内容如下,一级的 key 值时用来区分环境的,比如,dev、uat、pro 等,环境下的对象就是一次 HTTP 请求中能够获取到的环境变量了,你可以直接在请求的 HTTP 的脚本中通过 {{xx}} 占位符的方式获取到这里配置的参数

{"uat": {"baseUrl": "http://gateway.xxx.cn/","username": "","password": ""},"dev": {"baseUrl": "http://localhsot:8888/","username": "","password": ""}
}

那么在选择执行请求的时候,IDEA 就会让你选执行那个环境的配置,如:

结果断言

IDEA REST Client 可以针对接口的响应值进行脚本化的断言处理,立马从一个接口调试工具上升到测试工具了,比如:

### Successful test: check response status is 200
GET https://httpbin.org/status/200> {%
client.test("Request executed successfully", function() {client.assert(response.status === 200, "Response status is not 200");
});
%}

结果值暂存

试想下这样的场景,当一个系统需要通过认证才能访问的时候,如果用 postman 的时候,是不是先访问登录接口,然后获得 token 后,手动粘贴复制到新的调试接口的 header 参数里面去,这太麻烦了,IDEA REST Client 还有一个真香的功能,可以完美解决这个问题,请看下面的脚本:

### 演示POST请求
POST https://httpbin.org/post
Content-Type: application/json{"user": "admin","password": "123456"
}> {% client.global.set("auth_token", response.body.json.token); %}
### 演示GET请求GET https://httpbin.org/headers
Authorization: Bearer {{auth_token}}

在第一个认证的请求结束后,可以在 response 里拿到返回的 token 信息,然后我们通过脚本设置到了全局变量里,那么在接下来的接口请求中,就可以直接使用双大括号占位符的方式获取到这个 token 了

结语

postman 有口皆碑,确实是一个非常不错的必备工具,之前给比人推荐这种工具时总是安利他 postman。但是,IDEA REST Client 也真的很不错,值得尝试一下,后面安利这种工具就切换到 IDEA REST Client 了,postman 反正被我丢掉了。和第三方做接口对接时,项目里必备一个 rest-http.http 接口请求文件,满足自己的同时也成方便了他人。

作者:陈凯玲
链接:https://urlify.cn/QJZbya

body里写注释 postman_是时候扔掉 Postman 了,试试 IntelliJ IDEA 自带的高能神器!相关推荐

  1. 里写注释 postman_没用过这些IDEA插件?怪不得写代码头疼

    小伙伴们,大家好. 今天准备和大家一起分享一下实际工作中常用的几款能提升幸福感和工作效率的IDEA插件吧,也欢迎小伙伴们在评论区安利出你们用过的觉得非常不错的插件,大家一起交流进步. 1.Backgr ...

  2. body里写注释 postman_快速掌握Postman实现接口测试

    快速掌握Postman实现接口测试 Postman简介 Postman是谷歌开发的一款网页调试和接口测试工具,能够发送任何类型的http请求,支持GET/PUT/POST/DELETE等方法.Post ...

  3. body里写注释 postman_HTTP Status 415 – Unsupported Media Type(使用@RequestBody后postman调接口报错)...

    1.问题描述:使用springMVC框架后,添加数据接口中,入参对象没使用@RequestBody注解,造成postman发起post请求, from-data可以调通接口,但是raw调不通接口,然后 ...

  4. 自解释的代码根本不存在,老老实实写注释吧

    作者 | Sven Gregori 译者 | 薛命灯 有什么比花时间写注释更令人感到兴奋的事情吗?如果我没有猜错,你可能会说:"不好意思,所有事情都比写注释更令人感到兴奋".如果有 ...

  5. 代码自解释不是不写注释的理由

    有什么比花时间写注释更令人感到兴奋的事情吗?如果我没有猜错,你可能会说:"不好意思,所有事情都比写注释更令人感到兴奋".如果有人要你给代码加上注释,对你来说就像是一种侮辱.你的代码 ...

  6. 如何用js语句给mysql添加内容_在js里写SQL的方法

    在日新月异的前端领域中,前端工程师能做的事情越来越多,自从nodejs出现后,前端越来越有革了传统后端命的趋势,本文就再补一刀,详细解读如何在js代码中执行标准的SQL语句 为什么要在js里写SQL? ...

  7. 优秀的程序员真的不写注释吗? | 原力计划

    作者 | 沉默王二 责编 | 王晓曼 出品 | CSDN博客 前言 我在很多地方看到这样一个观点,"请停止写注释,因为只有烂的代码才需要注释."这个观点非常巧妙,它让我想起了孟子的 ...

  8. 程序员写代码要写注释吗?写你就输了

    前言:在职业发展道路上,需要不断提升自己,需要学习资源的,一起学习交流的欢迎加群[443128517],小编准备了学习视频,学习线路,自学书籍,职业发展视频.也可以加美女老师七七的微信.二维码放在下面 ...

  9. 给代码写注释时有哪些讲究?

    如果领导给你一个项目的源码让你阅读,并理解重构代码,但里面一句注释都没有,我想这肯定是之前同事"删库跑路"了. 看一份源码什么很重要?除了各种代码规范之外,还有一个比较重要的就是注 ...

最新文章

  1. Redis初学:6(List类型)
  2. 23-hadoop-hive的DDL和DML操作
  3. java 数字转26个字母和26个字母转数字
  4. 如何及时获得AI顶尖科研团队的最新论文与进展?你需要一份AI内参!
  5. 安卓虚拟linux系统教程,在Linux上模拟Android应用程序的3种方法 | MOS86
  6. 使用Python语言开发爬虫有什么优势?
  7. 具体的压栈指令,例子
  8. 经典算法题每日演练——第二十四题 梳排序
  9. Clojure 学习入门(11)- 宏 macro
  10. 解决Element的 InfiniteScroll 无限滚动组件报错
  11. 计算机一级b考试电子表格,计算机等级考试一级B第1-50套题
  12. 源码构建python3
  13. html叫编程语言吗,html是编程语言吗
  14. 性能优化,进无止境---内存篇(上)
  15. 用 .NET 3.5 创建 ToJSON() 扩展方法 (木野狐译)
  16. 20189220 余超《Linux内核原理与分析》第六周作业
  17. git push失败:Unable to access 'https://gitee.com/Lmui/proxy.git/': Could not resolve host: gitee.com
  18. 高考外语听力考试网络广播方案
  19. 湖北省级服务型制造示范企业、平台、项目遴选类别及申报条件
  20. 中小型企业的网站建设策划方案怎么写?

热门文章

  1. mysql一直出错_为什么我的mysql语句一直报错,找不到错误,望各位大佬指点一番...
  2. Android2017 这些技术 —— 你都了解过吗
  3. 如何通过JMX远程监控Solr?
  4. Cocos2d-x 3.x如何通过WebSocket连接服务器进行数据传输
  5. Quartz调用大全
  6. 很经典的独白,搞网络的童鞋们,你们懂得
  7. java 生产者消费者同步_经典线程同步问题(生产者消费者)--Java实现
  8. Java 并发(入门梳理)
  9. 精通数据科学_10篇文章变得更加精通数据科学
  10. rfc 查看工具_使用技术RFC作为管理工具的6课