python中session的使用案例詳解
python中session的使用
- 使用場景:當(dāng)接口之間有cookie數(shù)據(jù)之間的傳遞的情況下
- 為了確保接口之間cookie數(shù)據(jù)傳遞,一定要使用同一個session對象
- 接口返回的cookie數(shù)據(jù),存儲在session對象中
# 1.創(chuàng)建session對象 session = requests.session() # 2.使用session對象,實現(xiàn)之后所有的接口請求 session.get() session.post() session.put()
舉例
# 1.獲取驗證碼的接口 session.get(url="http://tpshop-test.itheima.net/index.php?m=Home&c=User&a=verify") # 2.使用session對象,實現(xiàn)登錄接口 data_dict_login = {"username": "13012345678", "password": "123456", "verify_code": "8888"} session.post(url="http://tpshop-test.itheima.net/index.php?m=Home&c=User&a=do_login",data_dict_login) # 3.使用session對象,完成查詢“我的訂單”接口 res_order = session.get(url="http://tpshop-test.itheima.net/Home/Order/order_list.html") print(res_order.text)
擴(kuò)展:Selenium如何獲取cookies保存起來用于下次訪問
一、獲取cookie
獲取到cookie后,保存到文件中
from selenium import webdriver import time import json from selenium.webdriver.common.by import By #創(chuàng)建webdriver 對象,指明使用chrome 瀏覽器驅(qū)動 wd = webdriver.Chrome() wd.implicitly_wait(10) #調(diào)用webdriver 對象的get方法,可以讓瀏覽器打開指定網(wǎng)址 wd.get('https://zhidao.baidu.com/activity/iknowduck/level?actId=47') input('網(wǎng)頁端登錄百度賬號后,請按回車鍵') cookie= wd.get_cookies() # #將獲得cookie 的信息打印 print(cookie) with open('baiducookies.txt','w') as f: # 將cookies保存為json格式 f.write(json.dumps(wd.get_cookies())) f.close()
二、加載cookie
通過讀取txt文件,添加到瀏覽器中
wd.add_cookie(cookie)
完整的讀取cookie的流程
from selenium import webdriver import time import json from selenium.webdriver.common.by import By from selenium.webdriver.common.keys import Keys from selenium.webdriver.chrome.options import Options from chatgpt_demo import chatgpt #創(chuàng)建webdriver 對象,指明使用chrome 瀏覽器驅(qū)動 wd= webdriver.Chrome() wd.implicitly_wait(10) #調(diào)用webdriver 對象的get方法,可以讓瀏覽器打開指定網(wǎng)址 wd.get('https://zhidao.baidu.com/activity/iknowduck/level?actId=47') # 首先清除由于瀏覽器打開已有的cookies wd.delete_all_cookies() time.sleep(10) #打開cookie文本,使用已保存的cookie登錄 with open('baiducookies.txt','r') as f: # 使用json讀取cookies 注意讀取的是文件 所以用load而不是loads cookies_list = json.load(f) for cookie in cookies_list: wd.add_cookie(cookie) wd.refresh() #刷新頁面 wd.refresh() #刷新頁面 time.sleep(6) #獲取當(dāng)前窗口的title First_handle = wd.current_window_handle j = 0 while j < 60: #try: for i in range(9): n = 1 #點擊第一個問題 questions = wd.find_elements(By.CSS_SELECTOR, 'div.q-item > div.q-title > span:nth-child(2) ') for question in questions: print('第{}個問題:'.format(n), question.text) n += 1 #將第一個問題,輸入catgpt在線智能回答 message = chatgpt(question.text) print(message) #with open("./output/{}.doc".format(prompt), "w") as of: # of.write(message) titles = question.text + '_百度知道' time.sleep(1) #點擊“回答”,按鈕 # answer = wd.find_element(By.CSS_SELECTOR,'.goto-anwser-btn') # print('點擊:',answer.text) wd.add_cookie(cookie) #帶cookie question.click() #點擊問題 time.sleep(3) #切換窗口,點擊“去回答”按鈕時,打開了新的窗口,但WebDriver對象對應(yīng)的 還是老窗口。這里要跟隨跳轉(zhuǎn) for handle in wd.window_handles: # 先切換到該窗口 wd.switch_to.window(handle) # 得到該窗口的標(biāo)題欄字符串,判斷是不是我們要操作的那個窗口 if 'titles' in wd.title: # 如果是,那么這時候WebDriver對象就是對應(yīng)的該該窗口,正好,跳出循環(huán), break #print(wd.title) #新窗口下,不管是否已有其他回答,都點擊“我來答按鈕” element = wd.find_element(By.CSS_SELECTOR, '#answer-bar') element.click()#點擊“我來答按鈕” #輸入文本 #新窗口,切換到第一級iframe框下,正文內(nèi)容 wd.switch_to.frame('ueditor_0') element = wd.find_element(By.CSS_SELECTOR,'body > p') print('正在輸入答案') element.send_keys(message) #先返回到主html,點擊提交按鈕 wd.switch_to.default_content() time.sleep(50) element = wd.find_element(By.CSS_SELECTOR,'div.addons.line > a') print(element.text) wd.add_cookie(cookie) # 帶cookie element.click() time.sleep(5) #做完一系列操作后關(guān)閉school_handle wd.close() # 切換窗口會第一個窗口 wd.switch_to.window(First_handle) #except: print("出錯{}次,正在重新運行程序。".format(j)) j += 1 wd.switch_to.window(First_handle) time.sleep(5) wd.refresh() # 刷新頁面 else: print('出錯太多次啦,程序已結(jié)束')
到此這篇關(guān)于Selenium如何獲取cookies保存起來用于下次訪問的文章就介紹到這了,更多相關(guān)Selenium獲取cookies內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解Selenium如何實現(xiàn)獲取cookies并保存
- Python?selenium?get_cookies獲取cookie不全的解決方案
- python+selenium自動化實戰(zhàn)攜帶cookies模擬登陸微博
- selenium攜帶cookies模擬登陸CSDN的實現(xiàn)
- Selenium獲取登錄Cookies并添加Cookies自動登錄的方法
- selenium中g(shù)et_cookies()和add_cookie()的用法詳解
- python中requests模擬登錄的三種方式(攜帶cookie/session進(jìn)行請求網(wǎng)站)
- Python處理session的方法整理
相關(guān)文章
opencv?python中cv.approxPolyDP函數(shù)詳細(xì)解釋
這篇文章主要給大家介紹了關(guān)于opencv?python中cv.approxPolyDP函數(shù)詳細(xì)解釋的相關(guān)資料,OpenCV中的approxPolyDP()函數(shù)用于對形狀進(jìn)行逼近,以減少多邊形的頂點數(shù),可以用于對圖像輪廓點進(jìn)行多邊形擬合,需要的朋友可以參考下2024-01-01使用Filter過濾python中的日志輸出的實現(xiàn)方法
這篇文章主要介紹了使用Filter過濾python中的日志輸出,本文給大家分享幾種方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07python中的Json模塊dumps、dump、loads、load函數(shù)用法詳解
這篇文章主要介紹了python中的Json模塊dumps、dump、loads、load函數(shù)用法講解,本文逐一介紹結(jié)合實例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2022-11-11Django 連接sql server數(shù)據(jù)庫的方法
這篇文章主要介紹了Django 連接sql server數(shù)據(jù)庫的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06python 虛擬環(huán)境調(diào)用allure報錯:FileNotFoundError: [WinError
python代碼調(diào)用命令行 allure命令報錯,提示找不到allure這個命令,本文就詳細(xì)的介紹了具體的解決方法,具有一定的參考價值,感興趣的可以了解一下2023-09-09