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

Python3中關(guān)于cookie的創(chuàng)建與保存

 更新時間:2018年10月21日 09:54:25   作者:回憶不說話  
今天小編就為大家分享一篇關(guān)于Python3中關(guān)于cookie的創(chuàng)建與保存的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

1.cookie的作用

cookie 是指某些網(wǎng)站為了辨別用戶身份、進行session跟蹤而儲存在用戶本地終端上的數(shù)據(jù),就像有些網(wǎng)站上的一些數(shù)據(jù)是需要登錄后才能看得到,那么想抓取某個頁面內(nèi)容,就需要用到cookie來模擬登陸了。

在用cookie模擬登陸的時候,需要用到python中的CookieJar,CookieJar中有一些子類,例如:

  • FileCookieJar,LWPCookieJar,MoziliaCookieJar
  • CookieJar 管理http生成的cookie,負責cookie的存儲工作,向http當中添加指定的cookie

MozillaCookieJarLWPCookieJar類都是FileCookieJar的子類。實現(xiàn)了具體的把cookie內(nèi)容保存為文件的方法。只是這兩個類對應的標準不同而已。

2 獲取cookie

from http.cookiejar import CookieJar,LWPCookieJar
from urllib.request import Request,urlopen,HTTPCookieProcessor,build_opener
from urllib.parse import urlencode
import ssl
# ----------------------------------------獲取cookie---------------------------
# 生成一個管理cookie的對象
cookie_obj = CookieJar()
# 創(chuàng)建一個支持cookie的對象,對象屬于HTTPCookieProcessor
cookie_handler = HTTPCookieProcessor(cookie_obj)  
#創(chuàng)建一個opener
opener = build_opener(cookie_handler)  
response = opener.open('http://www.baidu.com')
print(response)
#打印cookie
for cookie in cookie_obj:
  print('key:',cookie.name)
  print('value:',cookie.value)

3 保存cookie的文件

from http.cookiejar import CookieJar,LWPCookieJar
from urllib.request import Request,urlopen,HTTPCookieProcessor,build_opener
filename = 'neihan.txt'
# 設置cookie保存的文件
cookie_obj = LWPCookieJar(filename=filename)
# 創(chuàng)建一個支持cookie的對象,對象屬于HTTPCookieProcessor
cookie_handler = HTTPCookieProcessor(cookie_obj)
#創(chuàng)建一個opener
opener = build_opener(cookie_handler)
#請求網(wǎng)頁
response = opener.open('http://www.neihanshequ.com')
# 保存cookie到指定的文件當中去
# ignore_expires=True 即便目標cookie已經(jīng)在文件中存在,仍然對其寫入
# ignore_discard=True  即便cookie將要/已經(jīng)過期,仍然寫入
cookie_obj.save(ignore_expires=True,ignore_discard=True)

4 使用本地的cookie進行請求

from http.cookiejar import CookieJar,LWPCookieJar
from urllib.request import Request,urlopen,HTTPCookieProcessor,build_opener
cookie = LWPCookieJar()
#從文件中讀取cookie到變量
cookie.load('neihan.txt')
request = Request('http://www.neihanshequ.com')
# 創(chuàng)建一個支持cookie的對象,對象屬于HTTPCookieProcessor
cookie_handler = HTTPCookieProcessor(cookie)
#創(chuàng)建一個opener
opener = build_opener(cookie_handler)
#請求網(wǎng)頁
response = opener.open(request)
# print(response.read().decode())

5 使用cookie進行模擬登陸

from http.cookiejar import CookieJar,LWPCookieJar
from urllib.request import Request,urlopen,HTTPCookieProcessor,build_opener
from urllib.parse import urlencode
import ssl
cookie = LWPCookieJar(filename='meishi.txt')
cookie_handler = HTTPCookieProcessor(cookie)
opener = build_opener(cookie_handler)
headers={
  'User-Agent':'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:61.0) Gecko/20100101 Firefox/61.0'
}
post_url = 'https://i.meishi.cc/login.php?redirect=https%3A%2F%2Fi.meishi.cc%2Flogin.php%3Fac%3Dzhuce'
# urlencode對url當中的參數(shù)進行編碼
# urlencode()編碼的對象為字典類型
post_data = urlencode({
  'username':'***********',  #自己的登陸賬號
  'password':'************'  #自己的登陸密碼
})
# 請求url 并傳參,設置編碼方式
request = Request(post_url,bytes(post_data,encoding='utf-8'))
# 解決證書問題
ssl._create_default_https_context = ssl._create_unverified_context
response = opener.open(request)
print(response.read().decode())
cookie.save(ignore_discard=True,ignore_expires=True)

這里的post_url是抓包獲取來的

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • 在python的類中動態(tài)添加屬性與生成對象

    在python的類中動態(tài)添加屬性與生成對象

    這篇文章給大家介紹了如何在python的類中動態(tài)添加屬性和生成對象,文中通過幾個方面來進行介紹,對這感興趣的朋友們可以學習學習。
    2016-09-09
  • Python中Turtle庫改變畫筆(海龜)方向的兩種方法總結(jié)

    Python中Turtle庫改變畫筆(海龜)方向的兩種方法總結(jié)

    turtle庫是python標準庫之一,入門級繪圖庫,import turtle之后即可使用,下面這篇文章主要給大家介紹了關(guān)于Python中Turtle庫改變畫筆(海龜)方向的兩種方法,需要的朋友可以參考下
    2022-11-11
  • python中類的屬性和方法介紹

    python中類的屬性和方法介紹

    在本篇內(nèi)容里小編給大家整理了關(guān)于python中類的屬性知識點以及使用方法介紹,需要的朋友們參考下。
    2018-11-11
  • 實例Python處理XML文件的方法

    實例Python處理XML文件的方法

    這篇文章主要介紹了實例Python處理XML文件的方法,包括用Python處理XML大文件的情況,需要的朋友可以參考下
    2015-08-08
  • Python使用moviepy讀取字幕srt文件報錯的解決方法詳解

    Python使用moviepy讀取字幕srt文件報錯的解決方法詳解

    這篇文章主要為大家詳細介紹了Python使用moviepy讀取字幕srt文件報錯‘gbk‘?codec?can‘t?decode的兩種解決辦法,有需要的小伙伴可以跟隨小編一起學習一下
    2024-01-01
  • 使用python實現(xiàn)壓縮PDF文件大小的方法

    使用python實現(xiàn)壓縮PDF文件大小的方法

    壓縮 PDF 文件能有效減小文件大小并提高文件傳輸?shù)男?同時還能節(jié)省計算機存儲空間,除了使用一些專業(yè)工具對PDF文件進行壓縮,我們還可以通過 Python 來執(zhí)行該操作,本文將分享一個簡單有效的使用 Python 壓縮 PDF 文件的方法,需要的朋友可以參考下
    2024-06-06
  • Python數(shù)據(jù)庫安裝及MySQL?Connector應用教程

    Python數(shù)據(jù)庫安裝及MySQL?Connector應用教程

    這篇文章主要為大家介紹了Python數(shù)據(jù)庫安裝及MySQL Connector應用教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • web自動化測試Selenium點擊元素的常用方法

    web自動化測試Selenium點擊元素的常用方法

    在Web自動化測試中,Selenium提供多種點擊方法,常用的click()方法通過選中元素并觸發(fā)點擊事件,若click()方法不穩(wěn)定,可以采用JavaScript執(zhí)行點擊或使用ActionChains類模擬鼠標點擊,需要的朋友可以參考下
    2024-09-09
  • python 遞歸遍歷文件夾,并打印滿足條件的文件路徑實例

    python 遞歸遍歷文件夾,并打印滿足條件的文件路徑實例

    下面小編就為大家?guī)硪黄猵ython 遞歸遍歷文件夾,并打印滿足條件的文件路徑實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Python函數(shù)關(guān)鍵字參數(shù)及用法詳解

    Python函數(shù)關(guān)鍵字參數(shù)及用法詳解

    本文主要介紹了Python函數(shù)關(guān)鍵字參數(shù)及用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03

最新評論