人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

Python接口自動化之cookie、session應用詳解

發(fā)布日期:2022-02-06 08:46 | 文章來源:源碼之家

在上一篇Python接口自動化測試系列文章:Python接口自動化之淺析requests模塊post請求,介紹了post源碼,data、json參數(shù)應用場景及實戰(zhàn)。

以下介紹cookie、session原理及在接口自動化中的應用。

HTTP 協(xié)議是一種無狀態(tài)協(xié)議,即每次服務端接收到客戶端的請求時,都是一個全新的請求,服務器并不知道客戶端的歷史請求記錄;

Session 和 Cookie 的主要目的就是為了彌補 HTTP 的無狀態(tài)特性。

如果我們測試的接口有依賴關系怎么辦呢(比如購物支付時,需要先登錄),這時我們就要用到cookie和session技術來保持客戶端與服務器端連接的狀態(tài)。

一、cookie

1、cookie介紹

cookie是服務器發(fā)送到用戶瀏覽器并保存在本地的一小塊數(shù)據(jù),它會在瀏覽器下次向同一服務器再發(fā)起請求時被攜帶并發(fā)送到服務器上。通常,它用于告知服務端兩個請求是否來自同一瀏覽器,如保持用戶的登錄狀態(tài)。

2、cookie原理

① Cookie技術會根據(jù)從服務器端發(fā)送的響應報文內(nèi)的一個叫做Set-Cookie的首部字段信息,通知客戶端保存Cookie。

② 客戶端再向服務器端發(fā)送請求的時候,客戶端會在請求報文中加入Cookie值后發(fā)送出去。服務器端會檢查客戶端發(fā)送的請求中有沒有Cookie值,然后對比服務器上的記錄,最后確定是哪一個客戶端,之前的信息狀態(tài)是什么。

這樣一來,服務器就能夠分辨出發(fā)送請求的客戶端究竟是哪一個了。

二、session

1、session介紹

session是一種在服務端記錄用戶信息的技術,是在無狀態(tài)的HTTP協(xié)議下,服務端記錄用戶狀態(tài)時用于標識具體用戶的機制。它是在服務端保存的用來跟蹤用戶的狀態(tài)的數(shù)據(jù)結(jié)構(gòu),可以保存在文件、數(shù)據(jù)庫或者集群中。

2、session原理

Session是存放在服務器端、用來存放用戶數(shù)據(jù)的(類似于HashTable結(jié)構(gòu))。

當瀏覽器第一次發(fā)送請求時,服務器自動生成了一個HashTable和一個Session ID用來唯一標識這個HashTable,并將其通過響應發(fā)送到瀏覽器。

當瀏覽器第二次發(fā)送請求,會將前一次服務器響應中的Session ID放在請求中一并發(fā)送到服務器上,服務器從請求中提取出Session ID,并和保存的所有Session ID進行對比,找到這個用戶對應的HashTable,以此來達到共享數(shù)據(jù)的目的。

三、cookie和session區(qū)別

1. 存儲位置不同:

Cookie是將用戶數(shù)據(jù)通過加密的方式保存在客戶端,大多數(shù)情況Cookie存儲在瀏覽器;Session是用于控制客戶端和服務端的連接,Session存儲在服務器;

2. 存儲容量不同:

單個Cookie保存的數(shù)據(jù)不得超過4kb,一個站點最多20個Cookie,Session一般情況下沒有上限,不過建議不要存放太多東西,否則影響性能;

3. 存取方式不同:

Cookie只能用ASCII字符串,通過編碼方式獲取Unicode字符或者二進制數(shù)據(jù),不好存儲復雜的信息,而Session能存儲任何類型的數(shù)據(jù);

4. 隱私策略/安全性不同:

Cookie放在客戶端,可以進行Cookie欺騙,所以不安全,Session放在服務端,更加安全;

5. 有效期不同:

Cookie可以設置屬性達到長期有效,Session依賴于JSESSIONID的Cookie,Cookie JSESSIONID的過期時間默認為-1,只需要關閉窗口Session就會失效,就算不依賴Cookie,用UrL重寫也不能完成,如果Session超時時間過長,容易導致內(nèi)存溢出;

6. 服務器壓力不同:

Cookie保存在本地,不存在服務端壓力,Session保存在服務端,每個用戶產(chǎn)生一個Session,當訪問增多,會比較占用服務器的性能,如果主要考慮到減輕服務器性能方面,應當使用Cookie。

現(xiàn)在有登錄、充值兩個接口,在未登錄時,直接調(diào)用充值接口。

import requests
url = 'http://127.0.0.1:8000/recharge'
payload = {
 "mobilephone":"1530272****",
 "amount":100
}
recharge_res = requests.post(url,data=payload)
print(recharge_res.json())

請求結(jié)果:提示請先登錄。

{'status': 0, 'code': None, 'data': None, 'msg': '抱歉,請先登錄。'}

這時候,今天的主角cookie和session閃亮登場了。

四、cookie應用

import requests
 # 登錄接口
url = 'http://127.0.0.1:8000/user/login'
payload = {
 "mobilephone":"1530272****",
 "pwd":"123456"
}
login_res = requests.post(url,data=payload)
print(login_res.json())
# 獲取響應結(jié)果的cookies
cookies = login_res.cookies
print(cookies)
 # 充值接口
url = 'http://127.0.0.1:8000/recharge'
payload = {
 "mobilephone":"1530272****",
 "amount":100
}
# 充值接口請求時攜帶cookies
recharge_res = requests.post(url,data=payload,cookies=cookies)
print(recharge_res.json())

五、session應用

import requests
 
# 登錄接口
url = 'http://127.0.0.1:8000/user/login'
payload = {
 "mobilephone":"1530272****",
 "pwd":"123456"
}
# 創(chuàng)建session會話管理
session = requests.session()
login_res = session.post(url,data=payload)
print(login_res.json())
 
# 充值接口
url = 'http://127.0.0.1:8000/recharge'
payload = {
 "mobilephone":"1530272****",
 "amount":100
}
recharge_res = session.post(url,data=payload)
print(recharge_res.json())

到此這篇關于Python接口自動化之cookie、session應用詳解的文章就介紹到這了,更多相關Python接口自動化cookie、session應用內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持本站!

美國服務器租用

版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

相關文章

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務

7x24全年不間斷在線

專屬顧問服務

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務熱線

關注
微信

關注官方微信
頂部