欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python3+selenium實現cookie免密登錄的示例代碼

 更新時間:2020年03月18日 12:00:46   作者:不努力,誰會可憐你?  
這篇文章主要介紹了Python3+selenium實現cookie免密登錄的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

進過兩天的研究終于實現了cookie的免密登錄,其實就是session。特別開心,因為在Python爬蟲群里問那些大佬,可是他們的回答令我寒心,自己琢磨?。?!

靠誰比如靠自己,為此我總結下經驗,以免入門的小白再次踩這樣的吭。其實網上很多博客寫的都比較不詳細甚

首先問題自己思考,不懂得去群里問問,然后最重要的要理解事物的本質,只有理解后才能運用它;最后在百度一下把所有相關的博客都點開,一條一條的看一遍總結下規(guī)律,比較嘍的就舍棄,這樣基本上都能得到啟發(fā)作用。比如selenium的本質就是操作瀏覽器的,那么操作cookie也是操作瀏覽器的,并且用selenium打開瀏覽器時什么都沒有,如果進入某個網站就會生成cookie先關信息。等待,那么我們可以用selenium打開網站之后讓他清除所有cookie避免干擾,然后睡眠20秒以便等我們登陸,這是就會產生cookie,我們將它獲取下來就可以實現登陸了。

下面直接上代碼:

# 登錄
def login_jd():
  # 登錄前清除所有cookie
  browser.get('https://www.baidu.com/')
  browser.delete_all_cookies()
 
  # 打印登錄前的cookie
  cookieBefore = browser.get_cookies()
  print(cookieBefore)
 
  print("------------------------------------------------------------------------")
  time.sleep(2)
  list_cookies = [
    {'domain': '.baidu.com', 'httpOnly': False, 'name': 'H_PS_PSSID', 'path': '/', 'secure': False, 'value': '1420_21120_29074_29237_2518_2909_29134_2832_28585_26350_2913'},
    {'domain': '.baidu.com', 'expiry': 159184274.325927, 'httpOnly': False, 'name': 'BAIDUID', 'path': '/', 'secure': False, 'value': 'FF789623EA1785FF0D55ED0401D057B2:FG=1'},
    {'domain': 'www.baidu.com', 'expiry': 1563289, 'httpOnly': False, 'name': 'BD_UPN', 'path': '/', 'secure': False, 'value': '123143'},
    {'domain': '.baidu.com', 'expiry': 1560354688.892916, 'httpOnly': False, 'name': 'BDORZ', 'path': '/', 'secure': False, 'value': 'B490B5BF6F3CD40255D22BCDA1598'},
    {'domain': '.baidu.com', 'expiry': 1819468287.471656, 'httpOnly': True, 'name': 'BDUSS', 'path': '/', 'secure': False, 'value': 'tGem1JzblNpOa1VVek0yLThmbWR6RxENWZtcVNwUThpT2hCLTVsUFBQUFBJCQAAAAAAAAAAAEAAAA4MdBAd3d3d2dnZ2dnZWVlZWUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALkI~1y5CP9cVm'},
    {'domain': '.baidu.com', 'expiry': 2569420288, 'httpOnly': False, 'name': 'BIDUPSID', 'path': '/', 'secure': False, 'value': '587A2695FCD6D043A5FE5139E4F'},
    {'domain': '.baidu.com', 'expiry': 3707755.819949, 'httpOnly': False, 'name': 'PSTM', 'path': '/', 'secure': False, 'value': '156027786'},
    {'domain': 'www.baidu.com', 'httpOnly': False, 'name': 'BD_HOME', 'path': '/', 'secure': False, 'value': '1'}
  ]
 
  # 獲取之后的cookie
  cookies = browser.get_cookies()
  print(browser.get_cookies())
 
  # 將獲取的的所有cookies添加到瀏覽器
  for cookie in list_cookies:
    browser.add_cookie(cookie)
    print(cookie)
  time.sleep(2)
  # 刷新頁面即可更新cookie
  browser.refresh()
  time.sleep(505)
  browser.quit()

示例二:

首先使用用戶名和賬號,登錄獲取cookie

import json
import time
from selenium.webdriver.chrome.options import Options
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.common.exceptions import NoSuchElementException
 
 
class Crawler():
  def gather():
    chrome_options = Options()
    chrome_options.add_argument("window-size=1024,768")
    driver = webdriver.Chrome(chrome_options=chrome_options, executable_path='C:\devtool\Anaconda\Scripts\chromedriver')
    wait = WebDriverWait(driver, 1)
    ##登錄百度知道
    logurl = 'https://zhidao.baidu.com/'
    #登錄前清楚所有cookie
    driver.delete_all_cookies()
    driver.get(logurl)
    ##登錄前打印cookie
    print(driver.get_cookies())
 
    ##點擊登錄按鈕
    driver.find_element_by_xpath('//*[@id="userbar-login"]').click()
    # driver.find_element_by_id("userbar-login").click()
    time.sleep(2)
    ##首次嘗試的 默認進入掃碼登錄的界面
    try:
      footerULoginBtn = driver.find_element_by_xpath('//*[@id="TANGRAM__PSP_10__footerULoginBtn"]')
      footerULoginBtn.click() #切換到用戶名和密碼登錄
      footerULoginBtn_not_exist = False
    except:
      footerULoginBtn_not_exist = True
 
    ## 用戶名跟密碼的設置并點擊提交
    user = driver.find_element_by_name('userName')
    user.clear()
    pwd = driver.find_element_by_name('password')
    pwd.clear()
    submit = driver.find_element_by_id('TANGRAM__PSP_10__submit')
    time.sleep(2)
    user.send_keys('用戶名')
    pwd.send_keys('密碼')
    time.sleep(1)
    submit.click()
    time.sleep(1)
    ## 發(fā)送手機驗證碼 驗證
    ##點擊發(fā)送按鈕
    ###是否需要輸入手機驗證碼
    try:
      driver.find_element_by_xpath('//*[@id="TANGRAM__28__button_send_mobile"]').click()
      time.sleep(10)
      ##使用shell交互式,接受驗證碼
      message = input("Tell me the captcha: ")
      ##輸入驗證碼
      captcha = driver.find_element_by_xpath('//*[@id="TANGRAM__28__input_label_vcode"]')
      time.sleep(1)
      captcha.send_keys(message)
      time.sleep(1)
      ##點擊提交
      driver.find_element_by_xpath('//*[@id="TANGRAM__28__button_submit"]').click()
      time.sleep(3)
    except:
      time.sleep(1)
 
    ### 獲取cookie
    cookie = driver.get_cookies()
    print(cookie)
    jsonCookies = json.dumps(cookie)
    with open('vcyber.json', 'w') as f:
      f.write(jsonCookies)
 
    time.sleep(30)
 
Crawler.gather()

獲取cookie后,可以不用輸入密碼登錄

import json
import time
from selenium.webdriver.chrome.options import Options
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.common.exceptions import NoSuchElementException
 
 
class Crawler():
  def gather():
    chrome_options = Options()
 
    chrome_options.add_argument("window-size=1024,768")
    driver = webdriver.Chrome(chrome_options=chrome_options, executable_path='C:\devtool\Anaconda\Scripts\chromedriver')
    wait = WebDriverWait(driver, 1)
 
    ##登錄百度知道
    logurl = 'https://zhidao.baidu.com/'
 
    #登錄前清楚所有cookie
    driver.delete_all_cookies()
    driver.get(logurl)
 
    f1 = open('vcyber.json')
    cookie = f1.read()
    cookie = json.loads(cookie)
    for c in cookie:
      driver.add_cookie(c)
    # # 刷新頁面
    driver.refresh()
 
Crawler.gather()

到此這篇關于Python3+selenium實現cookie免密登錄的示例代碼的文章就介紹到這了,更多相關selenium cookie免密登錄內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • python調用攝像頭的示例代碼

    python調用攝像頭的示例代碼

    這篇文章主要介紹了python調用攝像頭的示例代碼,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-09-09
  • Python刪除docx文檔中的頁眉和頁腳的示例代碼

    Python刪除docx文檔中的頁眉和頁腳的示例代碼

    在日常工作中,我們經常需要處理文檔,其中包括刪除或修改頁眉和頁腳,本文將介紹如何使用Python編程語言和wxPython模塊創(chuàng)建一個簡單的GUI應用程序,幫助我們刪除docx文檔中的頁眉和頁腳,需要的朋友可以參考下
    2025-01-01
  • 基于Python下載網絡圖片方法匯總代碼實例

    基于Python下載網絡圖片方法匯總代碼實例

    這篇文章主要介紹了基于Python下載網絡圖片方法匯總代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • 在Windows8上的搭建Python和Django環(huán)境

    在Windows8上的搭建Python和Django環(huán)境

    作為一個.NET程序員,真心不喜歡以及PHP這種松散的語法。有人說,程序員應該多學幾門語言,本想學習Java,無奈感覺Java的語法太啰嗦了。很多人都推薦Python,說它的語法簡潔,執(zhí)行效率高。趁這兩天空閑,開始學習Python。
    2014-07-07
  • python實現按首字母分類查找功能

    python實現按首字母分類查找功能

    這篇文章主要介紹了python實現按首字母分類查找功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Python實現將目錄中TXT合并成一個大TXT文件的方法

    Python實現將目錄中TXT合并成一個大TXT文件的方法

    這篇文章主要介紹了Python實現將目錄中TXT合并成一個大TXT文件的方法,涉及Python針對目錄下文本文件的遍歷、讀取及寫入等技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • python opencv 實現讀取、顯示、寫入圖像的方法

    python opencv 實現讀取、顯示、寫入圖像的方法

    這篇文章主要介紹了python opencv 實現讀取、顯示、寫入圖像的方法,本文通示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Python實現五子棋人機對戰(zhàn)?和人人對戰(zhàn)

    Python實現五子棋人機對戰(zhàn)?和人人對戰(zhàn)

    這篇文章主要介紹了Python實現五子棋人機對戰(zhàn)?和人人對戰(zhàn),通過定義黑白子,落子位置以及獲勝規(guī)則展開詳細內容,需要的小伙伴可以參考一下
    2022-05-05
  • python批量連接服務器檢查容器是否正常

    python批量連接服務器檢查容器是否正常

    在生產中,我們可能有很多項目或者很多環(huán)境,可能會部署在幾百上千的服務器里面,我們該怎么定時去監(jiān)控這些服務器里面的容器服務器是否正常呢,本文就來為大家講解
    2024-01-01
  • Python3.8對可迭代解包的改進及用法詳解

    Python3.8對可迭代解包的改進及用法詳解

    這篇文章主要介紹了Python3.8對可迭代解包的改進及用法詳解,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10

最新評論