91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python利用requests庫進行接口測試的方法詳解

發布時間:2020-10-12 07:37:20 來源:腳本之家 閱讀:130 作者:MR_Hanjc 欄目:開發技術

前言

之前介紹了接口測試中需要關注得測試點,現在我們來看看如何進行接口測試,現在接口測試工具有很多種,例如:postman,soapui,jemter等等,對于簡單接口而言,或者我們只想調試一下,使用工具是非常便捷而且快速得,但是對于更復雜得場景,這些工具雖然也能實現,但是難度要比寫代碼更大,而且定制化受到工具得功能影響,會
遇到一些障礙,當然我們還要實現自動化等等,鑒于以上因素,我們還是要學會使用代碼進行接口測試,便于維護與擴展,或者算是我們知識得補充把~

requests庫是python用來發起http/https請求得第三方庫,支持get,post,put,delete等,requests特點是簡單便捷、功能豐富,能夠滿足日常測試需求,所以我們選取requests庫進行接口測試

運行環境:

  • 系統:mac os 10.13.5
  • python:3.6.4
  • requests:2.19.1

接口為自己編寫得測試接口,測試請使用自己得接口

第一部分:安裝

1.安裝python(自行安裝),不會的朋友們可以參考這篇文章:https://www.jb51.net/article/112486.htm

2.安裝requests(linux和mac os可能會遇到權限問題,sudo安裝即可)

pip install -U requests

3.驗證

localhost:~ mac$ python3
Python 3.6.4 (v3.6.4:d48ecebad5, Dec 18 2017, 21:07:28)
[GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import requests
>>>

沒有報錯說明python與requests環境都沒問題

第二部分:基礎部分

以一個簡單的get接口為例

import requests #導入requests模塊
response=requests.get("http://localhost:5000/hello")#對hello接口進行get請求,并獲取響應信息

1.響應信息(response)解析

print(response.text) 
print(response.content)
##輸出
你好
b'\xe4\xbd\xa0\xe5\xa5\xbd'

response.text是以str得形式返回得響應信息

response.content是以bytes形式返回

實際使用中根據自己得情況進行選擇

2.獲取狀態碼

print(response.status_code)
##輸出
200

3.獲取headers信息

print(response.headers)
##輸出
{'Content-Type': 'text/html; charset=utf-8', 'Content-Length': '6', 'Server': 'Werkzeug/0.14.1 Python/3.6.4', 'Date': 'Sun, 24 Jun 2018 02:55:27 GMT'}

4.獲取cookies信息

print(response.cookies)
##輸出
<RequestsCookieJar[]>

注意:這里與其他部分稍有不同,返回cookies的信息為cookies對象,而不是像前面部分返回得是字符串或者字典,cookies解析部分在后面會進行單獨說明

5.獲取請求url

print(response.url)
###輸出
http://localhost:5000/hello

6.獲取反序列化后的得信息:

print(response.json())
###輸出:
{'name': 'john'}

注意:只有在返回信息為json格式時才能使用,否則會報json異常

7.獲取響應時間

print(response.elapsed)
print(response.elapsed.microseconds)
print(response.elapsed.seconds)
print(response.elapsed.total_seconds())
##輸出
0:00:00.003773
3773
0
0.003773

第三部分:進階部分

通常我們要想獲取正確得響應信息需要傳遞一些參數,針對不同得請求,傳參方式稍有不通,下面我們來看一下
這里我部署了一個get接口和一個post接口,功能都是講獲取得請求參數返回回來,以便我們查看效果

1.get請求傳遞參數

params={"name":"john","age":17}
response=requests.get("http://localhost:5000/get_params",params=params)
print(response.text)
print(response.url)
##輸出
{"name": "john", "age": "17"}
http://localhost:5000/get_params?name=john&age=17

說明:

這里做了三件事,先定義一個參數字典p,然后將參數字典以params參數傳遞給get方法,最后將響應信息打印出來,從響應信息可以看到參數被正確得傳遞進去,requests幫我們把參數組合到了url里面

2.post請求傳遞參數

post傳遞參數和get有所不同,根據服務端取值方式進行不同方式得傳遞

如果是傳遞得json格式得參數

p={"name":"john","age":17}
response=requests.post("http://localhost:5000/post_params",json=p)
print(response.text)
###輸出:
{"name": "john", "age": 17}

如果是以html中form得形式傳遞參數,

response=requests.post("http://localhost:5000/post_params",data=p)
print(response.text)

如果form傳遞得是json格式需要以下面得方式

import json
response=requests.post("http://localhost:5000/post_params",data=json.dumps(p))
print(response.text)

說明:

需要將字典行駛得參數轉換為json格式,再進行傳遞

根據服務端得情況選中一種方式進行傳遞參數,通常情況下這三種情況可以滿足測試需求

第四部分:高級部分

1.操作cookies

有時候由于服務端需要取得cookies信息來進行用戶身份驗證, 或者另外一些用戶信息來進行邏輯處理,這時候我們在測試接口時需要手動獲取cookies信息和添加cookies信息到請求中

先看設置cookies信息

注:我這里部署了一個set_cookies接口,將cookies信息作為響應信息返回

my_cookies={"name":"john"}
response=requests.get("http://localhost:5000/set_cookies",cookies=my_cookies)
print(response.text)
##輸出
{"name": "john"}

說明:

這段代碼先定義了一個cookies字典,然后通過get方法,以cookies參數傳入,最后打印出響應信息,可以看到cookies被成功種入請求中

我們再說說如何獲取cookies并解析cookies信息

注:這里我部署了一個get_cookies接口,將{"name":"john"}作為cookies置入響應中

response=requests.get("http://localhost:5000/get_cookies")
cookies=response.cookies
print(cookies["name"])
##輸出:
john

說明:

獲取cookies對象得信息,我們只需要像獲取字段得value一樣即可,可以看到我們成功獲取到了john

2.headers

看完了cookies之后,header就一目了然了,但是我還是同樣部署兩個接口(一個set_headers,一個get_headers)

#設置headers
my_headers={"name":"john"}
response=requests.get("http://localhost:5000/set_headers",headers=my_headers)
print(response.text)
#獲取headers
response=requests.get("http://localhost:5000/get_headers")
print(response.headers.get("name"))
##輸出:
{"name": "john"}
john

3.session

session可以理解為一段對話,而這段對話會紀錄這次會話中得一些內容和狀態,當中斷這段對話,這些信息與狀態就丟失了session對象讓你能夠跨請求保持某些參數。它也會在同一個 Session 實例發出的所有請求之間保持 cookie, 期間使用 urllib3 的 connection pooling 功能。所以如果你向同一主機發送多個請求,底層的 TCP 連接將會被重用,從而帶來顯著的性能提升

使用方法

注:我這里部署兩個接口,一個hello接口(用來演示使用全局cookies,將請求cookies返回),一個world接口(用來演示使用全局headers,將請求headers返回)

#設置headers
my_info={"name":"john"}
#創建全局session對象
my_session=requests.session()
#設置全局cookies信息
my_session.cookies.set("name","john")
#設置全局headers信息
my_session.headers.update(my_info)
#演示全局cookies使用
response=my_session.get("http://localhost:5000/hello")
print(response.text)
#演示全局headers使用
response=my_session.get("http://localhost:5000/world")
print(response.text)
##輸出
{"name": "john"}
{"Host": "localhost:5000", "User-Agent": "python-requests/2.19.1", "Accept-Encoding": "gzip, deflate", "Accept": "*/*", "Connection": "keep-alive", "Name": "john", "Cookie": "name=john"}

4.設置timeout

通常接口都是為上游服務得,由于上游不能夠長時間等待接口返回信息,都會設置一個超時時間,超過了這個時間,會將這個結果丟棄,如果我們要監控線上接口有沒有超時情況,這時候我們發起請求的時候就需要設置一個超時時間,如果超過這個時間,就會拋出一個異常

response=requests.get("http://www.baidu.com",timeout=5)

說明:

將5這個超時時間以timeout參數傳入,這里得單位是秒

如果要想將連接(connect)與讀取(read)都進行設置,則需要傳入一個元組,第一個元素為connect超時事件,第二個元素為read超時時間

response=requests.get("http://www.baidu.com",timeout=(1,2))

5.hook

太晚了,先睡覺,明天補上~~

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

固安县| 大名县| 华容县| 桦南县| 武穴市| 泸西县| 贵州省| 新丰县| 固镇县| 正定县| 岳阳市| 将乐县| 肃北| 沁阳市| 崇明县| 特克斯县| 安仁县| 容城县| 镇平县| 那曲县| 蒙城县| 津市市| 德钦县| 西城区| 中阳县| 章丘市| 遂平县| 彭山县| 梁平县| 轮台县| 达尔| 长武县| 玉溪市| 秦安县| 雅安市| 汶川县| 德州市| 清徐县| 贡嘎县| 开原市| 喀什市|