五、postman使用

5.1.1 什么是Postman

? ??????????Postman 提供功能強(qiáng)大的 Web API 和 HTTP 請求的調(diào)試,它能夠發(fā)送任何類型的HTTP 請求

(GET, POST, PUT, DELETE…),并且能附帶任何數(shù)量的參數(shù)和 Headers。而且它還提供測試數(shù)據(jù)和環(huán)境

配置數(shù)據(jù)的導(dǎo)入導(dǎo)出,付費(fèi)的 Post Cloud 用戶還能夠創(chuàng)建自己的 Team Library 用來團(tuán)隊(duì)協(xié)作式的測

試,并能夠 將自己的測試收藏夾和用例數(shù)據(jù)分享給團(tuán)隊(duì)。

? ??????postman適用于不同的操作系統(tǒng),還支持postman瀏覽器擴(kuò)展程序、postman chrome應(yīng)用程序等。但

是 瀏覽器插件目前Google已經(jīng)停止更新了。

5.2 Postman下載和安裝

5.2.1 Postman的下載

????官網(wǎng)下載: 地址:https://www.getpostman.com/downloads/,選擇頁面中的“Download”,根據(jù)自己電腦配置, 選擇32位下載還是64位下載

5.2.2 Postman的安裝過程

? ??????1、雙擊下載好的安裝包

????????2、因?yàn)镻ostman是免安裝的,雙擊安裝包,自動安裝到本地電腦中

????????3、查看Postman界面,出現(xiàn)如下圖所示,說明安裝成功

????????4、登錄,點(diǎn)擊進(jìn)入workspace頁面

5.3 Postman主界面的介紹

5.3.1 工具欄

5.4 Postman基本操作

5.4.1 新建測試集、文件夾、請求用例

????????點(diǎn)擊collections,點(diǎn)擊+,點(diǎn)擊create new collection

????????點(diǎn)擊collection右邊的三個點(diǎn),點(diǎn)擊add request是添加請求,add folder是添加文件夾

5.4.2 get請求

新建一個get請求,如圖所示

? ??1.設(shè)置請求方式為get

????2.粘貼網(wǎng)址

? ?3.添加請求參數(shù),參數(shù)添加后會在url上顯示出來,如圖中所示的?id=1005008&page=1&size=100

????4.如果有請求頭,在請求頭的部分添加,也是鍵值對

????5.點(diǎn)擊send之后,下面顯示響應(yīng)數(shù)據(jù),可以是html,json,xml...

5.4.3 post請求

????1. 提交form表單,如圖所示

? ??????https://www.wanandroid.com/user/login

????????方法:POST

????參數(shù):

????username,password

????post請求的參數(shù)信息在Body中添加

????form表單提交需要選中x-www-form-urlencoded

????請求頭添加和get請求相同,在Headers中添加

need-to-insert-img

need-to-insert-img

2. json提交

下圖中,當(dāng)我們選擇JSON(application/json) 是會自動幫我們設(shè)置 headers 為 application/json

在這里就不截圖 舉例了

need-to-insert-img

3. xml提交

need-to-insert-img

4. 二進(jìn)制文件提交

need-to-insert-img

????其它請求方式如PUT,DELETE 大致流程和GET,POST 差不多,這里就不一一舉例說明了

5.4.4 授權(quán)Authorization

? ??Authorization,授權(quán)就是驗(yàn)證我們是否有權(quán)限從服務(wù)器訪問所需的數(shù)據(jù)。發(fā)送請求時,通常必須包含參數(shù)以確保請求有權(quán)訪問并返回所需的數(shù)據(jù),比如需要登錄之后才能訪問的數(shù)據(jù)。Postman提供的授權(quán)類型可以讓我們輕松處理Postman進(jìn)行接口測試中的身份驗(yàn)證協(xié)議。

在postman中Authorization分為以下幾種類型:

????????注意:應(yīng)當(dāng)注意:NTLM和BearerToken僅在Postman本地應(yīng)用程序中可用。所有其他授權(quán)類型都可以在Postman本地應(yīng)用程序和Chrome應(yīng)用程序中使用。

1. Inherit auth from parent

? ??向集合或文件夾添加授權(quán)。

????假設(shè)您在集合中添加了一個文件夾。在授權(quán)選項(xiàng)卡下,默認(rèn)的授權(quán)類型將被設(shè)置為“從父類繼承auth”。

????“從父”設(shè)置的“繼承auth”指示默認(rèn)情況下,該文件夾中的每個請求都使用父類的授權(quán)類型。在本例中,該集合使用“No Auth”,因此該文件夾使用“No Auth”,這意味著該文件夾中的所有請求將使用“No Auth”

????如果您希望將父集合授權(quán)類型保留為“No Auth”,但要更新這個特定的文件夾的授權(quán)助手,該怎么辦呢?您可以編輯文件夾的詳細(xì)信息,從類型下拉菜單中選擇“基本的Auth”,并輸入您的憑證。因此,這個文件夾中的每個請求都依賴于“基本的Auth”,而父集合中的其余請求仍然不使用任何授權(quán)

2. No Auth

? ??默認(rèn)情況下,“No Auth”出現(xiàn)在下拉菜單列表中。當(dāng)您不需要授權(quán)參數(shù)發(fā)送請求時,使用“No Auth”。

3. Bearer Token

Bearer Token是安全令牌。任何帶有Bearer Token的用戶都可以使用它來訪問數(shù)據(jù)資源,而無需使用加密密鑰。

使用Bearer Token:

????????第一步:從下拉菜單中選擇“Bearer Token”。

????????第二步:要設(shè)置請求的授權(quán)參數(shù),請輸入令牌的值。

????????第三步:點(diǎn)擊發(fā)送按鈕

4. Basic auth

? ??Basic Auth是一種授權(quán)類型,需要驗(yàn)證用戶名和密碼才能訪問數(shù)據(jù)資源。

使用基本身份驗(yàn)證:

????????第一步:從下拉菜單中選擇“Basic Auth”。

????????第二步:要設(shè)置請求的授權(quán)參數(shù),請輸入您的用戶名和密碼。

????????第三步:點(diǎn)擊發(fā)送按鈕。

5. Digest Auth

????????在“Digest Auth”流程中,客戶端向服務(wù)器發(fā)送請求,服務(wù)器返回客戶端的nonce和realm值;客戶端對用戶名、密碼、nonce值、HTTP請求方法、被請求資源URI等組合后進(jìn)行MD5運(yùn)算,把計(jì)算得到的摘要信息發(fā)送給服務(wù)端。服務(wù)器然后發(fā)回客戶端請求的數(shù)據(jù)。

????????通過哈希算法對通信雙方身份的認(rèn)證十分常見,它的好處就是不必把具備密碼的信息對外傳輸,只需將這些密碼信息加入一個對方給定的隨機(jī)值計(jì)算哈希值,最后將哈希值傳給對方,對方就可以認(rèn)證你的身份。

????????Digest思想同樣采如此,用了一種nonce隨機(jī)數(shù)字符串,雙方約好對哪些信息進(jìn)行哈希運(yùn)算即可完成雙方身份的驗(yàn)證。Digest模式避免了密碼在網(wǎng)絡(luò)上明文傳輸,提高了安全性,但它仍然存在缺點(diǎn),例如認(rèn)證報文被攻擊者攔截到攻擊者可以獲取到資源。

????????默認(rèn)情況下,Postman從響應(yīng)中提取值對應(yīng)的值。如果不想提取這些值,有以下兩種選擇:

????????在所選字段的高級部分中輸入您自己的值勾選“Yes,disable retrying the request”復(fù)選框。

6. OAuth 1.0

? ??????OAuth 1.0是一種可以讓我們在不公開密碼的情況下授權(quán)使用其他應(yīng)用程序的授權(quán)模式。

????在Postman中按照以下步驟使用OAuth 1.0授權(quán):

????在Authorization下來授權(quán)標(biāo)簽中選擇“OAuth 1.0”授權(quán)模式;在“Add authorization datato” 下拉選擇框中,選擇對應(yīng)的請求模式。

????當(dāng)選擇“Request Body/Request URL”時,Postman將檢查請求方法是POST還是PUT,以及請求主體類型是否是x-www-form-urlencoded;如果是這樣,Postman將增加授權(quán)參數(shù)到請求主體。對于所有其他情況,它會向URL添加授權(quán)參數(shù)。

7. OAuth 2.0

????OAuth 2.0作為OAuth 1.0的升級版本。在Postman中按照以下步驟進(jìn)行使用:

在Authorization下來授權(quán)標(biāo)簽中選擇“OAuth 2.0”授權(quán)模式在“Add authorization data to”下拉選擇框中,選擇對應(yīng)的請求模式;

設(shè)置請求的授權(quán)參數(shù),有以下三個選擇:

????????點(diǎn)擊“Get New Access Token”按鈕,在彈出的對話框中輸入對應(yīng)的參數(shù);單擊“Request Token”按鈕獲取對應(yīng)的Token。接下來有了對應(yīng)的Token后,就可以點(diǎn)擊“Send”按鈕發(fā)送請求了;

????????在“Access Token”輸入框中輸入一個Token,或者Token對應(yīng)的環(huán)境變量,然后就可以點(diǎn)擊“Send”按鈕發(fā)送請求了;

????????在“Available Tokens”下拉框中選擇已經(jīng)存在的Token,然后發(fā)送請求。

案例:

? ??????/**

? ? ? ? ? * 登錄

????????* https://www.liulongbin.top:8888/api/private/v1/login

????????* post

????????* 參數(shù):

????????* username(admin),password(123456)

????????*

????????* 上傳圖片

????* https://www.liulongbin.top:8888/api/private/v1/upload

????????* post

????* 請求頭 :authorization : Bearer

????eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1aWQiOjU wMCwicmlkIjowLCJpYXQiOjE2MTU4NjI

????zODksImV4cCI6MTYxNTk0ODc4OX0.Rr-????M1MTfVWER3i8KiIIlfP0mW6oHYu05Sz6WzCeaKSA

????* 參數(shù): file -- 文件

????*/

可以給接口集

9.5 Pre-request Script--預(yù)處理腳本

????Pre-request Script,翻譯中文為預(yù)處理腳本,是請求發(fā)送之前需要執(zhí)行的代碼片段,在我們點(diǎn)擊send發(fā)起請求之前,改區(qū)域的代碼先執(zhí)行。

????使用場景:例如請求中包含一個隨機(jī)數(shù)或者時間戳(時間的毫秒值),或者參數(shù)需要加密。

????1. 給一個接口添加預(yù)處理腳本:新建一個網(wǎng)絡(luò)請求,點(diǎn)擊Pre-request Script,寫入js腳本獲取時間的毫秒值(時間戳)

? ? ?2.給接口集添加預(yù)處理腳本:如圖所示,完成后以后接口集下面所有接口在請求的時候都會先執(zhí)行預(yù)請求腳本

????????????在輸入框右側(cè)有一些簡單的js腳本生成按鈕,可以通過按鈕生成

5.6 Tests內(nèi)置腳本

????????既然有在請求發(fā)起之前執(zhí)行的腳本,那么是否有在請求完成之后執(zhí)行的腳本呢? 有Tests里面輸入的腳本就是在網(wǎng)絡(luò)請求之后執(zhí)行的,Postman的強(qiáng)大之處在于其允許在對某一個request訪問的之前和之后分別運(yùn)行自定義的一段Javascript腳本,這樣直接就完成了一個chain request的效果,可以將數(shù)條request連結(jié)成一個流程完成一體化測試。

如下在Pre-request Script和Tests中分別輸入了js代碼,執(zhí)行如下如所示:

5.7 命令行運(yùn)行接口結(jié)合

? ??????9.7.1 命令行運(yùn)行

? ??????????執(zhí)行命令行前提條件是需要newman,newman是需要nodejs來安裝的,所以得先下載安裝node.node下載地址:https://nodejs.org/en/download/

? ??????????cmd模式下輸入node -v,回車,顯示node版本號,即為安裝成功

????????npm(node package manager):nodejs的包管理器,用于node插件管理(包括安裝、卸載、管理依賴等)

????????cnpm:淘寶團(tuán)隊(duì)的cnpm是npm在國內(nèi)的鏡像,可以用此代替官方版本(只讀),同步頻率目前為 10分鐘 一次以保證盡量與官方服務(wù)同步。

????????安裝完后查看版本cnpm -v

????????安裝newman:cnpm install newman --global

????????檢查是否安裝成功:newman -v

????????安裝newman-reporter-html

????????執(zhí)行cnpm install -g newman-reporter-html

????????在測試文件夾 pmtest 里面可以看到生成的一個 newman 文件夾,打開就可以看到生成的測試報告。

5.8 環(huán)境變量的使用

? ? 5.8.1 Postman 環(huán)境變量的應(yīng)用

? ??????點(diǎn)擊眼睛圖標(biāo)可以查看所有的環(huán)境變量和全局變量。點(diǎn)擊眼睛圖標(biāo)右邊的設(shè)置圖標(biāo)可以設(shè)置環(huán)境變量和全局變量。

????????環(huán)境變量可以分組設(shè)置,并且在使用的時候選擇其中一組環(huán)境變量。 使用環(huán)境變量 {{baseUrl}} 兩邊各量個花括號括起來 這個環(huán)境變量可以在url 中使用,也可以在header 中能使用,還能在請求體中使用

? ??????選中No Environment(選中已有環(huán)境就變成編輯了)--> 點(diǎn)擊眼睛-->點(diǎn)擊Add

????????案例:新建兩個環(huán)境,都創(chuàng)建相同的環(huán)境變量baseUrl值使用不同的網(wǎng)址,新建請求,使用{{baseUrl}},切換環(huán)境后,同一個請求訪問到的頁面不一樣

5.9 全局變量的使用

? ? 5.9.1 Postman全局變量的應(yīng)用

????????postman 的環(huán)境變量可以分組,但是全局變量不能分組,只能有一組全局變量,在設(shè)置和使用都類似于環(huán)境 變量。在下圖位置設(shè)置全局變量。

????????點(diǎn)擊右上角眼睛 --> 點(diǎn)擊Globals右邊的Edit,添加全局變量,點(diǎn)擊save保存,和環(huán)境變量一樣,通過{{timestamp}}引用

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,362評論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,577評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,486評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,852評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,600評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,944評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,944評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,108評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,652評論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,385評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,616評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,111評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,798評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,205評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,537評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,334評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,570評論 2 379

推薦閱讀更多精彩內(nèi)容