91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

django 基于中間件實現限制ip頻繁訪問過程詳解

發布時間:2020-10-10 21:37:31 來源:腳本之家 閱讀:174 作者:朱春雨 欄目:開發技術

額額,標題已經很醒目了,通過中間件去實現,其他方法也可以實現

瀏覽器前端傳來的請求,必須通過中間件,才能到后面路由,視圖函數,所以我們在中間件那里做一層處理,我們還需要知道是哪個ip,在什么時候,請求了幾次,這些數據是要知道,并且記錄下來,所以我創建了一個表,來存放這些信息數據

models文件:

 class Host_info(models.Model):
  host = models.CharField(max_length=32)
  count = models.IntegerField()
  start_time = models.DateTimeField()
  is_lock = models.CharField(max_length=32,default='2')

host:記錄主機ip

count:記錄請求的次數

start_time:記錄請求的時間

is_lock:記錄該ip的狀態,默認為2   2代表未鎖定,1代表鎖定

接下來就是自定義中間件了,并寫process_request方法,我們只對請求做處理,我先貼代碼,最后寫我遇到的一些問題

mymiddleware文件(我自定義的中間件):

 from django.utils.deprecation import MiddlewareMixin
 from django.shortcuts import render, HttpResponse
 from app01 import models
 import datetime
 class Md1(MiddlewareMixin):
  def process_request(self, request):
   url = request.path
   if url.startswith('/favicon.ico'):
    return HttpResponse
 class Md2(MiddlewareMixin):
  def process_request(self, request):
   now_time = datetime.datetime.now()
   host = request.META.get('REMOTE_ADDR')
   ret = models.Host_info.objects.filter(host=host).first()
   if ret:
    aa = now_time - ret.start_time
    if aa.seconds >= 60:
     ret.count = 1
     ret.start_time = now_time
     ret.is_lock = '2'
     ret.save()
     return None
    if aa.seconds < 60 and ret.is_lock == '1':
     return HttpResponse('登陸次數頻繁,一分鐘后再試')

    if ret.count < 4 and ret.is_lock == '2':
     if ret.count == 2:
      ret.is_lock = '1'
      ret.count = 0
      ret.save()
     else:
      ret.count += 1
      ret.start_time = now_time
      ret.save()
     return None
   else:
    models.Host_info.objects.create(host=host, start_time=now_time, count=1)
    return None

settings文件:

添加兩行代碼在MIDDLEWARE列表中:

'mymiddleware.Md1',
'mymiddleware.Md2',

并配置下面兩句,原因后面會說

TIME_ZONE = 'Asia/Shanghai'
USE_TZ = False

遇到兩個問題:

問題一:就是datetime,也就是時間分區問題,因為我數據表中需要保存到該ip訪問的時間,存的時候存的是datetime對象,但是我從數據庫中取出來這個時間,進行比較會報出錯誤,錯誤類型忘記了,我就打印了從數據庫中取出的時間數據, 發現,這個時間帶著時區,而我datetime.datetime.now()的時間是本機時間,根本不能相減,相比較。

網上收索才 知道django默認是有時間分區的,TIME_ZONE = 'UTC',USE_TZ = True,這兩句。

解決方式:在setting文件中將上面那兩句修改為TIME_ZONE = 'Asia/Shanghai',USE_TZ = False。這樣就解決了。

在django中但凡出現時間的話,這個地方需要注意下。

問題二:額額這個問題,我在寫的時候出現過,但是今天測試沒那個問題,反正寫上吧。我之前的錯誤就是我發出一個請求,

首先

第一個請求就是訪問到url,接著第二個請求就是發出favicon.ico這種類似的,請求ico這個。以這個情況來說問題吧,

你雖然在瀏覽器只發出一個請求,但是響應過來的網頁,里面可以還有其他請求,所以這中情況需要考慮到。

解決方式:我在對用戶ip做限制之前,加一個中間件,過濾掉其它的請求。,也就是上面的MD1。

## 代碼其實很簡單,主要是邏輯處理,你是怎么想就用代碼去實現。
## 對了,這里的數據存儲,你可以定義一個變量去存放存這些信息(也就是我數據表存放的這個)
## 這里唯一值得注意的就是時間了,你要很清楚知道時區這個問題。

補充一點,datetime的一個用法

例子中我用到datetime對象之間相減,取差多少秒,也就是這句

 aa = now_time - ret.start_time
 aa.seconds # 取到相差多少秒

這里的aa是datetime.timedelta類型

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

遂溪县| 丰宁| 台中县| 高清| 电白县| 枣阳市| 长岭县| 新沂市| 邢台市| 吉安市| 康乐县| 梨树县| 阳山县| 江川县| 手游| 高尔夫| 定州市| 古田县| 蒲江县| 青海省| 织金县| 延庆县| 天气| 囊谦县| 贵定县| 菏泽市| 黎川县| 宁武县| 张家川| 伊宁市| 正安县| 天台县| 玛多县| 开封市| 噶尔县| 浏阳市| 津南区| 永嘉县| 墨脱县| 东城区| 莱州市|