Django 中间件实现用户认证与IP频率限制

1.URL访问过滤

通过装饰器进行用户认证非常方便,但是在添加部分需要认证的功能时,就需要再次添加装饰器,如果通过中间件来实现,就不需要再进行添加的操作.

import re
LOGIN_URL = '/login/'
class MyLogin(MiddlewareMixin):
    def process_request(self, request):
        # 获取当前页面的路由
        url = request.get_full_path()
        path = request.path
        print(path)
        # 通过session判断是否登录
        is_login = request.session.get('is_login')
        # 判断当前页面是否是login页面
        if not re.match(path, LOGIN_URL):
            if not is_login:
                # 如果没有登录,重定向到login页面
                return redirect('/login/?next=%s' % url)

    def process_response(self, request, response):
        return response

2.做IP访问频率限制

为了防止某些IP恶意高频访问服务器,可以对这些IP进行限制,进行拦截.

import time
class OverTime(MiddlewareMixin):
    def process_request(self, request):
        # 获取客户端IP地址
        IP = request.META.get('REMOTE_ADDR')
        # 获取该IP地址的值,如果没有,给一个默认列表[]
        lis = request.session.get(IP, [])
        # 获取当前时间
        curr_time = time.time()
        # 判断操作次数是否小于3次
        if len(lis) < 3:
            # 如果小于3次,添加本次操作时间
            lis.append(curr_time)
            # 保存
            request.session[IP] = lis
        else:
            # 如果本次操作时间减去第一次操作时间小于60秒,则不让其继续操作
            if time.time() - lis[0] < 60:
                return HttpResponse('操作过于频繁')
            else:
                # 如果大于60秒则交叉复制
                lis[0], lis[1], lis[2] = lis[1], lis[2], time.time()
                # 保存
                request.session[IP] = lis

    def process_response(self, request, response):
        return response

转载于:https://www.cnblogs.com/louyefeng/p/10009739.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django可以通过中间件实现黑白名单和IP劫持的功能。下面给出一个实现的思路: 1. 创建一个中间件类,用于处理请求。可以在中间件的 `__init__` 方法中加载黑白名单和IP劫持配置(如从数据库或配置文件中加载)。 2. 实现中间件的 `process_request` 方法,在这个方法中,可以根据当前请求的IP地址来判断是否需要拦截请求。 3. 如果当前IP地址在黑名单中,则可以返回一个拒绝访问的响应;如果当前IP地址在白名单中,则可以继续处理请求;如果当前IP地址不在黑白名单中,但是IP劫持配置开启了,则可以将请求重定向到指定的页面。 4. 在Django的配置文件中,将中间件类添加到 `MIDDLEWARE` 列表中。 下面是一个简单的示例代码: ```python # middleware.py from django.conf import settings from django.http import HttpResponseForbidden, HttpResponseRedirect class IPFilterMiddleware: def __init__(self, get_response): self.get_response = get_response self.blacklist = set(settings.IP_BLACKLIST) self.whitelist = set(settings.IP_WHITELIST) self.hijack = settings.IP_HIJACK def __call__(self, request): ip = request.META.get('REMOTE_ADDR') if ip in self.blacklist: return HttpResponseForbidden('Your IP address is not allowed to access this website.') elif ip in self.whitelist: response = self.get_response(request) elif self.hijack: response = HttpResponseRedirect(settings.IP_HIJACK_URL) else: response = self.get_response(request) return response ``` 在上面的代码中,`settings.IP_BLACKLIST` 和 `settings.IP_WHITELIST` 分别是黑白名单,`settings.IP_HIJACK` 和 `settings.IP_HIJACK_URL` 分别表示是否开启IP劫持和重定向的页面。 在Django的配置文件中,需要将中间件添加到 `MIDDLEWARE` 列表中: ```python # settings.py MIDDLEWARE = [ # ... 'myapp.middleware.IPFilterMiddleware', # ... ] ``` 这样就可以通过中间件实现黑白名单和IP劫持的功能了。需要注意的是,这只是一个简单的示例代码,实际应用中可能需要更复杂的逻辑来处理请求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值