扔掉 Postman ,試試 IntelliJ IDEA 自帶的插件!
點(diǎn)擊“藍(lán)字”,關(guān)注,置頂公眾號(hào)
每日技術(shù)干貨,第一時(shí)間送達(dá)!
?
1
前言
接口調(diào)試是每個(gè)軟件開(kāi)發(fā)從業(yè)者必不可少的一項(xiàng)技能,一個(gè)項(xiàng)目的的完成,可能接口測(cè)試調(diào)試的時(shí)間比真正開(kāi)發(fā)寫(xiě)代碼的時(shí)間還要多,幾乎是每個(gè)開(kāi)發(fā)的日常工作項(xiàng)。
所謂工欲善其事必先利其器,在沒(méi)有嘗到IDEA REST真香之前,postman(chrome的一款插件)確實(shí)是一個(gè)非常不錯(cuò)的選擇,具有完備的REST Client功能和請(qǐng)求歷史記錄功能。
?
2
從postman到IDEA REST Client
?
首先postman的所有功能IDEA REST Client都具備了,如REST Client控制臺(tái)和歷史請(qǐng)求記錄
其次如果能夠在一個(gè)生產(chǎn)工具里完成開(kāi)發(fā)和調(diào)試的事情,干嘛要切換到另一個(gè)工具呢
然后IDEA REST Client還支持環(huán)境配置區(qū)分的功能,以及接口響應(yīng)斷言和腳本化處理的能力
IDEA REST Client的請(qǐng)求配置可以用文件配置描述,所以可以跟隨項(xiàng)目和項(xiàng)目成員共享
?
3
IDEA REST Client控制臺(tái)
?

可以看到,這個(gè)控制臺(tái)展示的功能區(qū)和postman已經(jīng)沒(méi)什么差別了,包括請(qǐng)求方式,請(qǐng)求參數(shù)和請(qǐng)求頭的填充都已經(jīng)包含了,特別說(shuō)明下的是,如果請(qǐng)求的方式是Authorization :Basic這種方式認(rèn)證的話,可以點(diǎn)擊下圖所示的按鈕,會(huì)彈出填充用戶名和密碼的窗口出來(lái),填完后會(huì)自動(dòng)補(bǔ)充到Authorization 的header里面去

?
4
歷史請(qǐng)求記錄
?
IntelliJ IDEA自動(dòng)將最近執(zhí)行的50個(gè)請(qǐng)求保存到http-requests-log.http 文件中,該文件存儲(chǔ)在項(xiàng)目的.idea / httpRequests / 目錄下。
使用請(qǐng)求歷史記錄,您可以快速導(dǎo)航到特定響應(yīng)并再次發(fā)出請(qǐng)求。文件內(nèi)容大如下圖所示,再次發(fā)出請(qǐng)求只要點(diǎn)擊那個(gè)運(yùn)行按鈕即可。
如果從請(qǐng)求歷史記錄再次發(fā)出請(qǐng)求,則其執(zhí)行信息和響應(yīng)輸出的鏈接將添加到請(qǐng)求歷史記錄文件的頂部。

構(gòu)建HTTP請(qǐng)求腳本 :
上面的歷史記錄就是一個(gè)完整的IDEA REST Client請(qǐng)求腳本,如果你是從控制臺(tái)觸發(fā)的,那么可以直接復(fù)制歷史請(qǐng)求記錄的文件放到項(xiàng)目里作為HTTP請(qǐng)求的腳本,給其他成員共享,如果不是,也可以直接新建一個(gè).http或者.rest結(jié)尾的文件,IDEA會(huì)自動(dòng)識(shí)別為HTTP請(qǐng)求腳本。
?
5
語(yǔ)法部分
### 演示POST請(qǐng)求POST {{baseUrl}}}get?show_env=1Accept:?application/json{?"name":"a"}### 演示GET請(qǐng)求GET {{baseUrl}}}/postContent-Type: application/x-www-form-urlencodedid=999&value=content首先通過(guò)###三個(gè)井號(hào)鍵來(lái)分開(kāi)每個(gè)請(qǐng)求體,然后請(qǐng)求url和header參數(shù)是緊緊挨著的,請(qǐng)求參數(shù)不管是POST的body傳參還是GET的
parameter傳參,都是要換行的
環(huán)境區(qū)分
細(xì)心的你可能發(fā)現(xiàn)了上面示例的代碼,沒(méi)有真實(shí)的請(qǐng)求地址,取而代之的,是一個(gè){{baseUrl}}的占位符,這個(gè)就是IDEA REST Client真香的地方,支持從指定的配置文件中獲取到環(huán)境相關(guān)的配置參數(shù),不僅baseUrl可以通過(guò)占位符替換,一些請(qǐng)求的參數(shù)如果和接口環(huán)境相關(guān)的都可以通過(guò)配置文件來(lái)區(qū)分。
{?"uat":
??????{?"baseUrl":?"http://gateway.xxx.cn/",
????????????"username":?"",?"password":?""
?????},?"dev": {
??????????"baseUrl":?"http://localhsot:8888/",
??????????"username":?"",
??????????"password":?""
??????????}
}
?
6
結(jié)果斷言
?
### Successful test:?check response status?is?200GET https://httpbin.org/status/200> {%client.test("Request executed successfully",?function()?{?client.assert(response.status === 200, "Response status is not 200");});%}結(jié)果值暫存
### 演示POST請(qǐng)求POST https://httpbin.org/postContent-Type: application/json{?"user":?"admin",?"password":?"123456"}> {% client.global.set("auth_token", response.body.json.token); %}### 演示GET請(qǐng)求GET https://httpbin.org/headersAuthorization: Bearer {{auth_token}}?
7
結(jié)語(yǔ)
?
postman有口皆碑,確實(shí)是一個(gè)非常不錯(cuò)的必備工具,之前給比人推薦這種工具時(shí)總是安利他postman。
但是,IDEA REST Client也真的很不錯(cuò),值得嘗試一下,后面安利這種工具就切換到IDEA REST Client了,postman反正被我丟掉了。
鏈接:https://my.oschina.net/keking/blog/3104972
往期推薦
