溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用定值Cookie實現反爬

發布時間:2023-04-04 14:20:51 來源:億速云 閱讀:157 作者:iii 欄目:開發技術

這篇文章主要講解了“怎么用定值Cookie實現反爬”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么用定值Cookie實現反爬”吧!

Cookie 生成

由于本案例需要用到一個特定的 Cookie ,所以我們需要提前將其生成,你可以直接設置一個固定的字符串,也可以使用 Python 加密模塊來加密一段文本,例如本案例加密 夢想橡皮擦。

下面是一個示例代碼,展示了如何使用 Python 的 hashlib 模塊進行加密:

import hashlib
# 要加密的文本
text = "夢想橡皮擦"
# 使用 sha256 算法進行加密
encrypted_text = hashlib.sha256(text.encode()).hexdigest()
print(encrypted_text)

在這個例子中,我們使用了 hashlib 模塊中的 sha256 算法對文本進行加密。這個算法生成了一個長度為 64 位的十六進制哈希值,用于表示加密后的文本。

注意,這個算法只能用于加密文本,而不能用于解密。因此,一旦文本被加密,就無法恢復成原來的文本,即不可逆加密/單項加密。

Python Flask 框架生成 Cookie

在 Python 的 Flask 框架中,可以使用 make_response 函數和 set_cookie 方法來生成一個 Cookie。

例如,下面的代碼片段展示了如何在 Flask 中設置一個名為 story 的 Cookie,并將它的值設為前文建立的加密串。

from flask import Flask, make_response
app = Flask(__name__)
@app.route('/')
def index():
    resp = make_response('Setting a cookie')
    encrypted_text = hashlib.sha256(text.encode()).hexdigest()
    resp.set_cookie('story', encrypted_text)
    return resp

在這個例子中,我們使用 make_response() 函數創建了一個響應對象,然后使用 set_cookie() 方法來設置 cookie。最后,我們將響應對象返回給客戶端。

注意,上面的代碼僅創建了一個簡單的 Cookie,它只有名稱和值兩個部分。你還可以使用其他可選參數來設置 Cookie 的其他屬性,例如過期時間、域名等。

接下來為大家在補充一下 make_response() 相關知識。

Flask make_response 加載模板

在 Flask 中,你可以使用 make_response() 函數和模板系統來生成帶有模板的響應。

下面是一個示例代碼,展示了如何使用 make_response() 函數加載模板:

from flask import Flask, make_response, render_template
app = Flask(__name__)
@app.route('/')
def index():
    # 加載模板并渲染
    rendered_template = render_template('index.html', title='夢想橡皮擦')
    # 使用 make_response 函數創建響應
    resp = make_response(rendered_template)
    return resp

在這個例子中,我們首先使用 Flask 的 render_template() 函數加載并渲染了名為 index.html 的模板。然后我們使用 make_response() 函數創建了一個響應對象,并將渲染后的模板作為響應的內容。最后,我們返回了這個響應對象給客戶端。

注意,你需要在 Flask 應用的模板目錄中存在名為 index.html 的模板文件,才能正常使用上述代碼。

然后我們將該視圖函數補充完整,代碼在 app/routes.py 文件中。

@app.route('/')
@app.route('/index')
def index():
    item = {
        "msg": "后臺傳遞信息"
    }
    # 訪問首頁生成一個 Cookie 值,該值用于訪問特定頁面
    rendered_template = render_template('index.html', title='夢想橡皮擦')
    resp = make_response(rendered_template)
    text = "夢想橡皮擦"
    # 使用 sha256 算法進行加密
    encrypted_text = hashlib.sha256(text.encode()).hexdigest()
    resp.set_cookie('story', encrypted_text)
    return resp

此時當我們訪問爬蟲訓練場首頁的時候,就會在 Cookie 中寫入一個加密之后的字符串。
通過開發者工具,可以查看到響應頭。

怎么用定值Cookie實現反爬

最后一步,就是在 Python Flask 框架中判斷剛剛的 Cookie 值,如果存在則響應數據,否則返回 403。

Flask 判斷指定 cookie 是否存在

在 Python 的 Flask 框架中,你可以使用 request.cookies 屬性來判斷指定的 Cookie 是否存在。

例如,下面的代碼片段展示了如何判斷一個名為 story 的 Cookie 是否存在:

from flask import Flask, request
app = Flask(__name__)
@app.route('/')
def index():
    if 'story' in request.cookies:
        # 如果存在 'story' cookie,則執行相應操作
        # ...
    else:
        # 如果不存在 'story' cookie,則執行相應操作
        # ...

將代碼補充完整,文件是 app/antispider/index.py。

@antispider.route('/cookie_demo')
def cookie_demo():
    if 'story' in request.cookies:
        # 如果存在 'story' cookie,則執行相應操作
        # ...
        return render_template("antispider/cookie_demo.html")
    else:
        return "沒有權限", 403

補充知識點

在 Python 的 Flask 框架中,除了使用 set_cookie() 方法設置 cookie 以外,還有其他幾種操作 cookie 的方法。

下面是一些常用的操作 cookie 的方法:

  • 設置 cookie 的值:你可以使用 set_cookie() 方法來設置 cookie 的值。例如:

from flask import Flask, make_response
app = Flask(__name__)
@app.route('/')
def index():
    resp = make_response('Setting a cookie')
    resp.set_cookie('user', 'xiangpica')
    return resp
  • 獲取 cookie 的值:你可以使用 request.cookies字典來獲取 cookie 的值。例如:

from flask import Flask, request
app = Flask(__name__)
@app.route('/')
def index():
    user = request.cookies.get('user')
    return user
  • 刪除 cookie:你可以使用 set_cookie() 方法并將 cookie 的過期時間設為過去的時間來刪除 cookie。例如:

from flask import Flask, make_response
app = Flask(__name__)
@app.route('/')
def index():
    resp = make_response('Deleting a cookie')
    resp.set_cookie('user', '', expires=0)
    return resp

感謝各位的閱讀,以上就是“怎么用定值Cookie實現反爬”的內容了,經過本文的學習后,相信大家對怎么用定值Cookie實現反爬這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女