IDEA REST Client接口测试插件
今天博主跟大家聊一聊IDEA REST Client
接口测试插件!不喜勿喷,如有建议欢迎补充、讨论!
关于安装和汉化可以观看博主的这篇文章《下载安装及汉化 》,安装完毕重启VsCode!
前言
接口调试是每个软件开发从业者必不可少的一项技能,一个项目的完成,可能接口测试调试的时间比真正开发写代码的时间还要多,几乎是每个开发的日常工作项。
所谓工欲善其事必先利其器,在没有尝到IDEA REST真香之前,postman(PS:chrome的一款插件,当然也可以下载客户端进行使用!)确实是一个非常不错的选择,具有完备的REST Client功能和请求历史记录功能。
但是当使用了IDEA REST之后,IDEA REST Client具有postman的所有功能,而且还有postman没有的功能,继续往下看。
从Postman到IDEA REST Client
真香定律的原因有如下几个:
- 首先
postman
的所有功能IDEA REST Client
都具备了,如REST Client
控制台和历史请求记录 - 其次如果能够在一个生产工具里完成开发和调试的事情,干嘛要切换到另一个工具呢
- 然后
IDEA REST Client
还支持环境配置区分的功能,以及接口响应断言和脚本化处理的能力 IDEA REST Client
的请求配置可以用文件配置描述,所以可以跟随项目和项目成员共享
IDEA REST Client控制台
打开你的
Idea
—>从顶层工具栏依次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-urlencoded
id=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
了
当然
如果和第三方做接口对接时,项目里可以有一个rest-http.http
接口请求文件,满足自己的同时也成方便了他人。
- 如果有中文乱码问题,就把
Request Body
选择的Empty
改为Text
,Text
内容可以为空。 - 如果需要传输
json
对象,需要设置请求头——Context-Type application/json
json
对象需写在上述text中,点击输入框右侧图标,打开窗口即可输入。
- 如果请求报
400
或者415
,请仔细检查参数。 request.getParameter/getParameterMap
都只能获取到你在request Parameters
中设置的键值对,是无法获取json
对象中的值的。- 关于使用
spring
的依赖注入时的迷之报错,当你他的报错原因是没有找到对应的加了@Component
注解的类。也就是说,idea
认为在项目启动时,spring
容器中不存在这个类。既然如此的话,你可以在你的Mapper
或Repository
接口上加入@Repository
或者@Component
注解,即可完美解决报错问题。但这个方法对于整个spring
应用来讲有什么副作用,暂时还没有发现。
最后
-
更多参考精彩博文请看这里:陈永佳的博客
-
喜欢博主的小伙伴可以加个关注、点个赞哦,持续更新嘿嘿!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/97585.html