接口測試及常用接口測試工具

轉載自:https://www.cnblogs.com/feng0815/p/7509541.html

首先,什么是接口呢?

接口一般來說有兩種,一種是程序內部的接口,一種是系統對外的接口。

系統對外的接口:比如你要從別的網站或服務器上獲取資源或信息,別人肯定不會把數據庫共享給你,他只能給你提供一個他們寫好的方法來獲取數據,你引用他提供的接口就能使用他寫好的方法,從而達到數據共享的目的,比如說咱們用的app、網址這些它在進行數據處理的時候都是通過接口來進行調用的。

程序內部的接口:方法與方法之間,模塊與模塊之間的交互,程序內部拋出的接口,比如bbs系統,有登錄模塊、發帖模塊等等,那你要發帖就必須先登錄,要發帖就得登錄,那么這兩個模塊就得有交互,它就會拋出一個接口,供內部系統進行調用。

一、常見接口:

1、webService接口:是走soap協議通過http傳輸,請求報文和返回報文都是xml格式的,我們在測試的時候都用通過工具才能進行調用,測試。可以使用的工具有SoapUI、jmeter、loadrunner等;

2、http api接口:是走http協議,通過路徑來區分調用的方法,請求報文都是key-value形式的,返回報文一般都是json串,有get和post等方法,這也是最常用的兩種請求方式。可以使用的工具有postman、RESTClient、jmeter、loadrunner等;

二、前端和后端:

?在說接口測試之前,我們先來搞清楚這兩個概念,前端和后端。

????? 前端是什么呢,對于web端來說,咱們使用的網頁,打開的網站,這都是前端,這些都是html、css寫的;對于app端來說呢,它就是咱們用的app,android或者object-C(開發ios上的app)開發的,它的作用就是顯示頁面,讓我們看到漂亮的頁面,以及做一些簡單的校驗,比如說非空校驗,咱們在頁面上操作的時候,這些業務邏輯、功能,比如說你購物,發微博這些功能是由后端來實現的,后端去控制你購物的時候扣你的余額,發微博發到哪個賬號下面,那前端和后端是怎么交互的呢,就是通過接口。

????? 前面說的你可能不好理解,你只需記住:前端負責貌美如花,后端負責掙錢養家。

三、什么是接口測試:

接口測試是測試系統組件間接口的一種測試。接口測試主要用于檢測外部系統與系統之間以及內部各個子系統之間的交互點。測試的重點是要檢查數據的交換,傳遞和控制管理過程,以及系統間的相互邏輯依賴關系等。

所謂接口測試就是通過測試不同情況下的入參與之相應的出參信息來判斷接口是否符合或滿足相應的功能性、安全性要求。接口測試沒有頁面,它是通過接口規范文檔上的調用地址、請求參數,拼接報文,然后發送請求,檢查返回結果,它只需測入參和出參就行了,相對來說簡單了不少。

四、接口組成

接口都有那些部分組成呢?

首先,接口文檔應該包含以下內容:

1、接口說明

2、調用url

3、請求方法(get\post)

4、請求參數、參數類型、請求參數說明

5、返回參數說明

由接口文檔可知,接口至少應有請求地址、請求方法、請求參數(入參和出參)組成,部分接口有請求頭header。

標頭 (header):是服務器以HTTP協議傳HTML資料到瀏覽器前所送出的字串,在標頭與 HTML 文件之間尚需空一行分隔,一般存放cookie、token等信息

有同學問我header和入參有什么關系?它們不都是發送到服務器的參數嗎?

OK,首先,它們確實都是發送到服務器里的參數,但它們是有區別的,header里存放的參數一般存放的是一些校驗信息,比如cookie,它是為了校驗這個請求是否有權限請求服務器,如果有,它才能請求服務器,然后把請求地址連同入參一起發送到服務器,然后服務器會根據地址和入參來返回出參。也就是說,服務器是先接受header信息進行判斷該請求是否有權限請求,判斷有權限后,才會接受請求地址和入參的。

五、為什么要做接口測試:

大家都知道,接口其實就是前端頁面或APP等調用與后端做交互用的,所以好多人都會問,我功能測試都測好了,為什么還要測接口呢?OK,在回答這個問題之前,先舉個栗子:

比如測試用戶注冊功能,規定用戶名為6~18個字符,包含字母(區分大小寫)、數字、下劃線。首先功能測試時肯定會對用戶名規則進行測試時,比如輸入20個字符、輸入特殊字符等,但這些可能只是在前端做了校驗,后端可能沒做校驗,如果有人通過抓包繞過前端校驗直接發送到后端怎么辦呢?試想一下,如果用戶名和密碼未在后端做校驗,而有人又繞過前端校驗的話,那用戶名和密碼不就可以隨便輸了嗎?如果是登錄可能會通過SQL注入等手段來隨意登錄,甚至可以獲取管理員權限,那這樣不是很恐怖?

所以,接口測試的必要性就體現出來了:

①、可以發現很多在頁面上操作發現不了的bug

②、檢查系統的異常處理能力

③、檢查系統的安全性、穩定性

④、前端隨便變,接口測好了,后端不用變

六、接口測試怎么測:

在進行接口測試前,還需要了解:

1)、GET和POST請求:

如果是get請求的話,直接在瀏覽器里輸入就行了,只要在瀏覽器里面直接能請求到的,都是get請求,如果是post的請求的話,就不行了,就得借助工具來發送。

GET請求和POST請求的區別:

1、GET使用URL或Cookie傳參。而POST將數據放在BODY中。

2、GET的URL會有長度上的限制,則POST的數據則可以非常大。

3、POST比GET安全,因為數據在地址欄上不可見。

4、一般get請求用來獲取數據,post請求用來發送數據。

其實上面這幾點,只有最后一點說的是比較靠譜的,第一點post請求也可以把數據放到url里面,get請求其實也沒長度限制,post請求看起來參數是隱式的,稍微安全那么一些些,但是那只是對于小白用戶來說的,就算post請求,你通過抓包也是可以抓到參數的。所以上面這些面試的時候你說出來就行了。

2)、http狀態碼

每發出一個http請求之后,都會有一個響應,http本身會有一個狀態碼,來標示這個請求是否成功,常見的狀態碼有以下幾種:

1、200 2開頭的都表示這個請求發送成功,最常見的就是200,就代表這個請求是ok的,服務器也返回了。

2、300 3開頭的代表重定向,最常見的是302,把這個請求重定向到別的地方了,

3、400 400代表客戶端發送的請求有語法錯誤,401代表訪問的頁面沒有授權,403表示沒有權限訪問這個頁面,404代表沒有這個頁面

4、500 5開頭的代表服務器有異常,500代表服務器內部異常,504代表服務器端超時,沒返回結果

接下來再說接口測試怎么測:

1)、通用接口用例設計

①、通過性驗證:首先肯定要保證這個接口功能是好使的,也就是正常的通過性測試,按照接口文檔上的參數,正常傳入,是否可以返回正確的結果。

②、參數組合:現在有一個操作商品的接口,有個字段type,傳1的時候代表修改商品,商品id、商品名稱、價格有一個是必傳的,type傳2的時候是刪除商品,商品id  是必傳的,這樣的,就要測參數組合了,type傳1的時候,只傳商品名稱能不能修改成功,id、名稱、價格都傳的時候能不能修改成功。

③、接口安全:

???? 1、繞過驗證,比如說購買了一個商品,它的價格是300元,那我在提交訂單時候,我把這個商品的價格改成3元,后端有沒有做驗證,更狠點,我把錢改成-3,是不   是我的余額還要增加?

???? 2、繞過身份授權,比如說修改商品信息接口,那必須得是賣家才能修改,那我傳一個普通用戶,能不能修改成功,我傳一個其他的賣家能不能修改成功

???? 3、參數是否加密,比如說我登陸的接口,用戶名和密碼是不是加密,如果不加密的話,別人攔截到你的請求,就能獲取到你的信息了,加密規則是否容易破解。

???? 4、密碼安全規則,密碼的復雜程度校驗

④、異常驗證:

  所謂異常驗證,也就是我不按照你接口文檔上的要求輸入參數,來驗證接口對異常情況的校驗。比如說必填的參數不填,輸入整數類型的,傳入字符串類型,長度  是10的,傳11,總之就是你說怎么來,我就不怎么來,其實也就這三種,必傳非必傳、參數類型、入參長度。

2)、根據業務邏輯來設計用例

  根據業務邏輯來設計的話,就是根據自己系統的業務來設計用例,這個每個公司的業務不一樣,就得具體的看自己公司的業務了,其實這也和功能測試設計用例是  一樣的。

???   舉個例子,拿bbs來說,bbs的需求是這樣的:

??   ?1、登錄失敗5次,就需要等待15分鐘之后再登錄

??   ?2、新注冊的用戶需要過了實習期才能發帖

??   ?3、刪除帖子扣除積分

??   ?4、......

??   像這樣的你就要把這些測試點列出來,然后再去造數據測試對應的測試點。

、用什么工具測

接口測試的工具很多,比如?postman、RESTClient、jmeter、loadrunner、SoapUI等,本人首推的測試工具是postman和jmeter,接下來就簡單介紹下如何使用這兩款工具進行接口測試,其他工具本次暫不介紹。

1)、Postman是谷歌的一款接口測試插件,它使用簡單,支持用例管理,支持get、post、文件上傳、響應驗證、變量管理、環境參數管理等功能,可以批量運行,并支持用例導出、導入。

jmeter是一款100%純Java編寫的免費開源的工具,它主要用來做性能測試,相比loadrunner來說,它內存占用小,免費開源,輕巧方便、無需安裝,越來越被大眾所喜愛。

注:以下用例中所用地址皆為本人在本地所搭的環境,外網無法訪問,見諒。

①、獲取用戶信息:該接口用于通過userid獲取用戶信息

  請求地址:http://192.168.1.102:8081/getuser

  請求方式:POST/GET

?????? 入參:

參數數據類型(長度)是否必傳備注

useridStringY用戶id

?出參:

參數數據類型(長度)備注

codeint狀態碼200為成功,500為異常

ageint年齡

idstring用戶id

nameString用戶姓名

? postman中請求如下

?jmeter中請求如下:

? ②、獲取用戶信息:需要添加header,Content-Type application/json

1.1??? 請求地址

http://192.168.1.102:8081/getuser2

1.2??? 請求方式

get/post

1.3??? ?入參

參數數據類型(長度)是否必傳備注

useridStringY用戶id

?1.4??? ?出參

參數數據類型(長度)備注

codeint狀態碼200為成功,500為異常

useridint用戶id

namestring用戶名稱

ageint用戶年齡

?postman測試如下,本次入參為json類型,當然文檔中沒說非要用json,用其他方式也是可以的

?jmeter測試如下

?③、修改用戶余額2

1.1??? ?功能描述

功能描述:需要添加cookie,token token是寫死的token12345

1.2??? 請求地址

http://192.168.1.102:8081/setmoney2

1.3??? 請求方式

Post

1.4??? 入參

參數數據類型(長度)是否必傳備注

useridStringY用戶id

moneyStringY修改的余額數值

?1.5??? ?出參

參數數據類型(長度)備注

codeint狀態碼200為成功,500為異常

successString狀態

? postman測試如下:

?jmeter測試如下:

?④文件上傳

postman:

jmeter:

⑤、請求webService接口

請求webService接口需要用到的工具是SoapUI,如下圖


下面內容轉自:https://www.cnblogs.com/houzhizhe/p/6836126.html

Postman做各種類型的http接口測試

首先,做接口測試前要有明確的接口文檔(e.g.?http://test.nnzhp.cn/wiki/index.php?doc-view-59) ,假設已經在PC上安裝好了Postman。

1. 普通的以key-value傳參的get請求

e.g. 獲取用戶信息

Get請求,寫入url拼好參數,發送請求,查看結果。


2. 以Json串傳參的post請求

e.g. 獲取用戶余額

Post請求,寫入url,點擊Body->raw, 寫入Json串參數,發送請求

返回Authorization查看結果

3.? 請求時需要http權限驗證

e.g. 修改用戶余額

Post請求,寫入url和參數,Type選Basic Auth ,填寫用戶名和密碼(如有需要接口文檔會給出),發送請求

4. ?請求時需要添加請求標頭

e.g. 獲取用戶信息2

Get請求,寫入url和參數,點擊Headers并添加header(如有需要接口文檔中會給出),發送請求,查看結果

5.? 請求時需要添加Cookie

e.g. 修改用戶余額2

Post請求,寫入url和參數,打開插件Interceptor(如果提示安裝需要在外網環境下安裝,安裝一次一勞永逸),在Headers里寫入Cookie,值按接口文檔所給的填寫好,發送請求,查看結果。


6. 請求通過某個接口上傳文件

??? e.g.上傳文件

??? Post請求,寫入url,在Body中修改text為File,填入參數名,選擇本地文件,發送請求,查看結果

Postman管理請求

我們可以在Postman 創建Collection(可以按照項目,按照功能模塊等看實際情況定)然后把多個請求保存在Collection里,這樣就可以實現簡單的管理。另外我們可以對Collection做一些簡單的操作,比如把Collection導出到本地備份,批量運行Collection中的請求,等等,批量運行的速度好像很慢啊,這可能就是沒人用Postman做批量接口測試的原因吧,可以大膽嘗試看看,還會有更多的收獲。


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

推薦閱讀更多精彩內容