首先,什么是接口呢? 接口一般來說有兩種,一種是程序內(nèi)部的接口,一種是系統(tǒng)對外的接口。 一、常見接口: 1、webService接口:是走soap協(xié)議通過http傳輸,請求報文和返回報文都是xml格式的,我們在測試的時候都用通過工具才能進行調(diào)用,測試??梢允褂玫墓ぞ哂蠸oapUI、jmeter、loadrunner等; 2、http api接口:是走http協(xié)議,通過路徑來區(qū)分調(diào)用的方法,請求報文都是key-value形式的,返回報文一般都是json串,有get和post等方法,這也是最常用的兩種請求方式??梢允褂玫墓ぞ哂衟ostman、RESTClient、jmeter、loadrunner等; 二、前端和后端: 在說接口測試之前,我們先來搞清楚這兩個概念,前端和后端。 三、什么是接口測試: 接口測試是測試系統(tǒng)組件間接口的一種測試。接口測試主要用于檢測外部系統(tǒng)與系統(tǒng)之間以及內(nèi)部各個子系統(tǒng)之間的交互點。測試的重點是要檢查數(shù)據(jù)的交換,傳遞和控制管理過程,以及系統(tǒng)間的相互邏輯依賴關系等。 OK,上面是百度百科上說的,下面才是我說的 其實我覺得接口測試很簡單,比一般的功能測試還簡單(這話我先這樣說,以后可能會刪O(∩_∩)O哈?。F(xiàn)在找工作好多公司都要求有接口測試經(jīng)驗,也有好多人問我(也就兩三個人)什么是接口測試,本著不懂也要裝懂的態(tài)度,我會說:所謂接口測試就是通過測試不同情況下的入?yún)⑴c之相應的出參信息來判斷接口是否符合或滿足相應的功能性、安全性要求。 我為啥說接口測試比功能測試簡單呢,因為功能測試是從頁面輸入值,然后通過點擊按鈕或鏈接等傳值給后端,而且功能測試還要測UI、前端交互等功能,但接口測試沒有頁面,它是通過接口規(guī)范文檔上的調(diào)用地址、請求參數(shù),拼接報文,然后發(fā)送請求,檢查返回結果,所以它只需測入?yún)⒑统鰠⒕托辛耍鄬碚f簡單了不少。 四、接口組成 接口都有那些部分組成呢? 首先,接口文檔應該包含以下內(nèi)容: 1、接口說明 由接口文檔可知,接口至少應有請求地址、請求方法、請求參數(shù)(入?yún)⒑统鰠ⅲ┙M成,部分接口有請求頭header。 標頭 (header):是服務器以HTTP協(xié)議傳HTML資料到瀏覽器前所送出的字串,在標頭與 HTML 文件之間尚需空一行分隔,一般存放cookie、token等信息 有同學問我header和入?yún)⒂惺裁搓P系?它們不都是發(fā)送到服務器的參數(shù)嗎? OK,首先,它們確實都是發(fā)送到服務器里的參數(shù),但它們是有區(qū)別的,header里存放的參數(shù)一般存放的是一些校驗信息,比如cookie,它是為了校驗這個請求是否有權限請求服務器,如果有,它才能請求服務器,然后把請求地址連同入?yún)⒁黄鸢l(fā)送到服務器,然后服務器會根據(jù)地址和入?yún)矸祷爻鰠?。也就是說,服務器是先接受header信息進行判斷該請求是否有權限請求,判斷有權限后,才會接受請求地址和入?yún)⒌摹?/span> 五、為什么要做接口測試: 大家都知道,接口其實就是前端頁面或APP等調(diào)用與后端做交互用的,所以好多人都會問,我功能測試都測好了,為什么還要測接口呢?OK,在回答這個問題之前,先舉個栗子: 比如測試用戶注冊功能,規(guī)定用戶名為6~18個字符,包含字母(區(qū)分大小寫)、數(shù)字、下劃線。首先功能測試時肯定會對用戶名規(guī)則進行測試時,比如輸入20個字符、輸入特殊字符等,但這些可能只是在前端做了校驗,后端可能沒做校驗,如果有人通過抓包繞過前端校驗直接發(fā)送到后端怎么辦呢?試想一下,如果用戶名和密碼未在后端做校驗,而有人又繞過前端校驗的話,那用戶名和密碼不就可以隨便輸了嗎?如果是登錄可能會通過SQL注入等手段來隨意登錄,甚至可以獲取管理員權限,那這樣不是很恐怖? 所以,接口測試的必要性就體現(xiàn)出來了: ①、可以發(fā)現(xiàn)很多在頁面上操作發(fā)現(xiàn)不了的bug 六、接口測試怎么測: 在進行接口測試前,還需要了解: 1)、GET和POST請求: 2)、http狀態(tài)碼 每發(fā)出一個http請求之后,都會有一個響應,http本身會有一個狀態(tài)碼,來標示這個請求是否成功,常見的狀態(tài)碼有以下幾種: 接下來再說接口測試怎么測: 1)、通用接口用例設計 ①、通過性驗證:首先肯定要保證這個接口功能是好使的,也就是正常的通過性測試,按照接口文檔上的參數(shù),正常傳入,是否可以返回正確的結果。 ③、接口安全: ④、異常驗證: 2)、根據(jù)業(yè)務邏輯來設計用例 七、用什么工具測 接口測試的工具很多,比如 postman、RESTClient、jmeter、loadrunner、SoapUI等,本人首推的測試工具是postman和jmeter,接下來就簡單介紹下如何使用這兩款工具進行接口測試,其他工具本次暫不介紹。 1)、Postman是谷歌的一款接口測試插件,它使用簡單,支持用例管理,支持get、post、文件上傳、響應驗證、變量管理、環(huán)境參數(shù)管理等功能,可以批量運行,并支持用例導出、導入。 jmeter是一款100%純Java編寫的免費開源的工具,它主要用來做性能測試,相比loadrunner來說,它內(nèi)存占用小,免費開源,輕巧方便、無需安裝,越來越被大眾所喜愛。 注:以下用例中所用地址皆為本人在本地所搭的環(huán)境,外網(wǎng)無法訪問,見諒。 ①、獲取用戶信息:該接口用于通過userid獲取用戶信息 請求地址:http://192.168.1.102:8081/getuser 請求方式:POST/GET 入?yún)ⅲ?/span>
出參:
postman中請求如下
jmeter中請求如下:
②、獲取用戶信息:需要添加header,Content-Type application/json 1.1 請求地址 http://192.168.1.102:8081/getuser2 1.2 請求方式 get/post 1.3 入?yún)?/span>
1.4 出參
postman測試如下,本次入?yún)閖son類型,當然文檔中沒說非要用json,用其他方式也是可以的
jmeter測試如下
③、修改用戶余額2 1.1 功能描述 功能描述:需要添加cookie,token token是寫死的token12345 1.2 請求地址 http://192.168.1.102:8081/setmoney2 1.3 請求方式 Post 1.4 入?yún)?/span>
1.5 出參
postman測試如下:
jmeter測試如下:
④文件上傳 postman:
jmeter:
⑤、請求webService接口 請求webService接口需要用到的工具是SoapUI,如下圖
在jmeter里請求如下: |
|