RESTful WebServices是一个类似jmeter,postman的工具。可以使用纯文本编辑。
在IDEA中的位置Tools->Http client->Test Restful WebService
。点击之后出现如下界面
点击红色部分即可出现文本编辑页面
Add Request
快速生成模板,也可输入gtr
生成get
请求模板,ptr
生成post
请求模板,mptr
生成multipart/form-data
请求模板。Examples
,其中包含很多复杂的http请求集合示例,可以参考,非常全面。编写HTTP请求时,可以使用variables来参数化其元素 。变量可以保存请求的主机,端口和路径的值,查询参数或值,标头值或在请求主体内部或外部文件中使用的任意值。
要在请求中提供变量,请将其括在双花括号中,如{{variable}}
。变量名称只能包含字母,数字,下划线符号 _
或连字符-
。
变量的值可以通过以下方式获取:
默认方式动态生成的$uuid
,$timestamp
和$randomInt
预定义的动态变量
通过环境变量为每个环境显式提供
编写响应处理脚本方式定义。即使用 client.global.set
每次您运行请求时,动态变量都会生成一个值:
$uuid
:生成通用的唯一标识符(UUID-v4)$timestamp
:生成当前的UNIX时间戳$randomInt
:生成介于0到1000之间的随机整数。例如:
GET http://localhost/api/get?id={{$uuid}}
环境变量使您可以在项目内部存储一组环境定义。例如,您可以创建和使用{{host}}
变量,而不是在请求中显式提供主机名。执行请求时,可以在定义的环境之间进行选择,然后将其发送到特定的主机:
环境变量在环境文件中定义。
在项目内部,创建以下文件:
http-client.env.json
{
"development": {
"host": "localhost",
"id-value": 12345,
"username": "",
"password": "",
"my-var": "my-dev-value"
},
"production": {
"host": "example.com",
"id-value": 6789,
"username": "",
"password": "",
"my-var": "my-prod-value"
}
}
http-client.private.env.json
{
"development": {
"host": "localhost",
"id-value": 12345,
"username": "",
"password": "",
"my-var": "my-dev-value"
},
"production": {
"host": "example.com",
"id-value": 6789,
"username": "",
"password": "",
"my-var": "my-prod-value"
}
}
GET http://{{host}}/api/json/get?id={{id-value}}&key={{unresolved_var}}
Authorization: Basic {{username}} {{password}}
Content-Type: application/json
{
"key": {{my-var}}
}
当您执行上述请求时,IntelliJ IDEA会在定义的执行环境之间提供一个选择:
该脚本包含两个对象,分别为client
和response
。该脚本在http请求完成后执行。
client
存储会话元数据,可以在脚本内部对其进行修改。该client
直到IntelliJ IDEA关闭存在。
response
保存有关接收到的响应的信息:其内容类型,状态,响应正文等。
Client
用于存储全局变量,跟随IDEA启动和关闭,重启IDEA变量不会保存。
名称 | 描述 |
---|---|
global |
用于全局变量存储,用于设置,检索,或删除变量。在HTTP请求中,您可以使用语法{{variable_name}} 访问存储在client.global 中名称为variable_name 的变量。 |
名称 | 参数 | 描述 |
---|---|---|
test |
testName (string)func (function) |
创建名为testName ,body 为func 的测试。 |
assert |
condition (boolean)message (string) |
检查指定的 condition 是true ; 否则引发异常。可选message 参数用作异常消息。 |
log |
text |
打印text 到控制台 |
global
全局变量存储对象该global
对象用作变量存储,并用于设置,检索或删除变量。
名称 | 参数 | 描述 |
---|---|---|
set |
varName(String) varValue(String) |
将具有varName 名称的变量保存到存储器中,并将其值设置为 varValue 。 |
get |
varName(String) | 返回varName 变量的值。 |
isEmpty |
检查global 对象是否未定义变量。 |
|
clear |
从变量存储中 删除变量varName 。 |
|
clearAll |
从变量存储中删除所有变量。 |
该response
对象保存有关接收到的HTTP响应的信息(响应内容,标头,状态等),并提供对headers
和contentType
嵌套对象的访问。
responses属性
名称 | 描述 |
---|---|
body (字符串或者对象) |
响应内容,如果响应的内容类型 为application / json,则为字符串或JSON对象 。 |
headers (ResponseHeaders) |
响应报头存储对象 |
status (int) |
响应状态,例如200或404。 |
contentType (ContentType) |
contentType对象,用于保存Content-Type响应标头值上的数据。 |
该ResponseHeaders
对象用于检索有关响应头值的数据。
方法
名称 | 参数 | 描述 |
---|---|---|
valueOf | headerName (string) |
检索headerName 响应头的第一个值,或者 null 如果headerName 响应头不存在。 |
valuesOf | headerName (string) |
检索包含headerName 响应标头的所有值的数组。如果headerName 响应头不存在,则返回一个空数组。 |
用于保存Content-Type响应标头值上的数据。
属性
名称 | 描述 |
---|---|
mimeType(string) | 响应的MIME类型,例如text / plain, text / xml,application / json |
charset(string) | 响应字符集的字符串表示形式,例如utf-8。 |
### Check response status, headers, and content-type
GET https://httpbin.org/get
> {%
client.test("Request executed successfully", function() {
client.assert(response.status === 200, "Response status is not 200");
});
client.test("Headers option exists", function() {
client.assert(response.body.hasOwnProperty("headers"), "Cannot find 'headers' option in response");
});
client.test("Response content-type is json", function() {
var type = response.contentType.mimeType;
client.assert(type === "application/json", "Expected 'application/json' but received '" + type + "'");
});
%}
在此示例中,我们将从接收到的响应中捕获一个值到环境变量中,然后将其用于后续请求中。
POST https://httpbin.org/post
Content-Type: application/json
{
"token": "my-secret-token"
}
//设置环境变量
> {%
client.global.set("auth_token", response.body.json.token);
%}
//使用上面定义的变量
GET https://httpbin.org/headers
Authorization: Bearer {{auth_token}}
Content-Type: application/json
{
"token": "my-secret-token"
}
//设置环境变量
> {%
client.global.set("auth_token", response.body.json.token);
%}
//使用上面定义的变量
GET https://httpbin.org/headers
Authorization: Bearer {{auth_token}}