佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > Python3使用Selenium獲取session和token方法詳解

Python3使用Selenium獲取session和token方法詳解

熱門標(biāo)簽:Win7旗艦版 客戶服務(wù) 百度AI接口 呼叫中心市場需求 語音系統(tǒng) 企業(yè)做大做強(qiáng) 電話運(yùn)營中心 硅谷的囚徒呼叫中心

一、背景說明

之前寫了一款簡單的api模糊測試工具,之前系統(tǒng)可以使用http Base認(rèn)證現(xiàn)在改成session形式并加上了token。

最簡單的改造方法,是自己先在瀏覽器手動(dòng)登錄,然后提取出session和token(系統(tǒng)token在整個(gè)會(huì)話期間可重復(fù)使用)填到模糊測試工具中即可。但這種非全自動(dòng)化的方式不到萬不得已不想用。

最直接的方法,最使用requests按登錄流程依次發(fā)包登錄即可。但其中的難點(diǎn)是密碼是加密提交的,詢問開發(fā)人員說是DES加密;DES加密不難,但是用不同的語言編寫的加密算法與別人的結(jié)果完全一致那就比較費(fèi)工夫。

最后的方法,那就是使用selenium登錄避開密碼的構(gòu)造,這種方法的關(guān)鍵點(diǎn)在于:selenium是基于圖形界面操作的,沒有直接的辦法能獲取request和response的數(shù)據(jù)包,在這種情況下如何獲取session和token。

自己動(dòng)web前端的存儲(chǔ)并沒有很深入了解,一直想的是如何獲取selenium request和response的數(shù)據(jù)包從中提取session和token,直到看到這篇文章才想起前端的變量(尤其是restful中的全局變量)會(huì)放存localStorage和sessionStorage中,從中提取session和token即可。

二、環(huán)境搭建

2.1 下載驅(qū)動(dòng)

下載驅(qū)動(dòng)文件,放到后續(xù)python文件同級(jí)目錄下或加入到環(huán)境變量中即可。其中Chrome驅(qū)動(dòng)要注意Driver版本與瀏覽器版本對(duì)應(yīng)要求。

Firefox驅(qū)動(dòng)下載地址:https://github.com/mozilla/geckodriver/releases

Chrome驅(qū)動(dòng)下載地址:http://chromedriver.chromium.org/downloads

Safari驅(qū)動(dòng)下載地址:https://webkit.org/blog/6900/webdriver-support-in-safari-10/

Edge驅(qū)動(dòng)下載地址:https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/

2.2 安裝selenium

pip install selenium

三、程序?qū)崿F(xiàn)

3.1 系統(tǒng)狀況

手動(dòng)登錄系統(tǒng)后,查看存儲(chǔ)狀況如下圖所示,sessionid和token分別存儲(chǔ)在sessionStorage的sessionId和token兩個(gè)變量中

3.2 實(shí)現(xiàn)代碼

import json
import time
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By

class GetSessionAndToken():
  def __init__(self):
    # 啟用無頭模式,可選
    browser_options = webdriver.FirefoxOptions()
    browser_options.add_argument('--headless')
    browser_options.add_argument('--disable-gpu')
    self.browser = webdriver.Firefox(firefox_options=browser_options)
    # self.browser = webdriver.Chrome()

  # 登錄系統(tǒng),具體到自己系統(tǒng)時(shí)需要自行修改
  def login_system(self):
    # 登錄用戶名密碼,改成目標(biāo)系統(tǒng)用戶名密碼
    username = "admin"
    password = "123456"
    # 登錄頁面url,改成目標(biāo)系統(tǒng)登錄頁面
    url = "https://10.10.6.93/#login"
    self.browser.get(url)
    # 顯性等待,直到用戶名控件加載出來才進(jìn)行下一步
    WebDriverWait(self.browser,20,0.5).until(EC.presence_of_element_located((By.ID,"txtUserName")))
    # 填寫用戶名
    self.browser.find_element_by_id("txtUserName").send_keys(username)
    # 填寫密碼
    self.browser.find_element_by_id("txtPassword").send_keys(password)
    # 點(diǎn)擊登錄
    self.browser.find_element_by_id("btnLogin").click()
    # 強(qiáng)制等待5秒,待session和token都成功返回并存到瀏覽器中
    # restful隱性等待不太好用?self.browser.implicitly_wait(5)
    time.sleep(5)

  # 獲取sessionid
  def get_sessionid(self):
    # 是要從localStorage中獲取還是要從sessionStorage中獲取,具體看目標(biāo)系統(tǒng)存到哪個(gè)中
    # window.sessionStorage和直接寫sessionStorage是等效的
    # 一定要使用return,不然獲取到的一直是None
    # get的Item不一定就叫sessionId,得具體看目標(biāo)系統(tǒng)把sessionid存到哪個(gè)變量中
    sessionid = self.browser.execute_script('return sessionStorage.getItem("sessionId");')

    # 另外sessionid一般都直接通過返回Set-Cookies頭設(shè)置到Cookie中,所以也可以從Cookie讀取
    # 獲取瀏覽器所有Set-Cookie,返回對(duì)象是字典列表
    # cookies = self.browser.get_cookies()
    # 獲取單項(xiàng)Cookie,是不是叫sessionId取決于系統(tǒng)存成什么變量,單項(xiàng)Cookie是字典
    # cookie = self.browser.get_cookie("sessionId")
    # cookie = cookie["value"]
    # print(f"{cookies}")
    return sessionid

  # 獲取token
  def get_token(self):
    # 是要從localStorage中獲取還是要從sessionStorage中獲取,具體看目標(biāo)系統(tǒng)存到哪個(gè)中
    # window.sessionStorage和直接寫sessionStorage是等效的
    # 一定要使用return,不然獲取到的一直是None
    # get的Item不一定就叫token,得具體看目標(biāo)系統(tǒng)把token存到哪個(gè)變量中
    token = self.browser.execute_script('return sessionStorage.getItem("token");')
    # print(f"{token}")
    return token

  def __del__(self):
    # 退出程序時(shí)關(guān)閉瀏覽器
    self.browser.close()

if __name__ == "__main__":
  obj = GetSessionAndToken()
  obj.login_system()
  sessionid = obj.get_sessionid()
  token = obj.get_token()
  print(f"sessionid為: {sessionid}\n"
     f"token為:   {token}")

3.3 實(shí)現(xiàn)效果

更多關(guān)于Python獲取session和token方法請(qǐng)查看下面的相關(guān)鏈接

您可能感興趣的文章:
  • python中requests模擬登錄的三種方式(攜帶cookie/session進(jìn)行請(qǐng)求網(wǎng)站)
  • Python處理session的方法整理
  • python使用requests.session模擬登錄
  • python3+requests接口自動(dòng)化session操作方法
  • Python爬蟲番外篇之Cookie和Session詳解
  • python中requests庫session對(duì)象的妙用詳解
  • 剖析Python的Tornado框架中session支持的實(shí)現(xiàn)代碼
  • 在Python的Django框架的視圖中使用Session的方法
  • Python ORM框架SQLAlchemy學(xué)習(xí)筆記之映射類使用實(shí)例和Session會(huì)話介紹

標(biāo)簽:海南 長沙 崇左 喀什 山西 安康 山西 濟(jì)南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python3使用Selenium獲取session和token方法詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    铁岭市| 朝阳县| 荆州市| 镇安县| 神池县| 宁晋县| 和田县| 金寨县| 沙雅县| 济源市| 洪洞县| 惠水县| 尤溪县| 噶尔县| 赤峰市| 黑河市| 凤阳县| 上虞市| 合川市| 西乌| 本溪| 隆子县| 佛坪县| 牟定县| 建平县| 景泰县| 纳雍县| 长乐市| 锡林浩特市| 连城县| 徐州市| 离岛区| 色达县| 汾西县| 嘉禾县| 绥棱县| 宁河县| 怀远县| 罗田县| 成都市| 福海县|