>  기사  >  백엔드 개발  >  사용자 인증 및 IP 빈도 제한을 구현하는 Django 미들웨어의 코드 예

사용자 인증 및 IP 빈도 제한을 구현하는 Django 미들웨어의 코드 예

不言
不言앞으로
2018-11-24 15:59:232616검색

이 기사의 내용은 사용자 인증 및 IP 빈도 제한을 구현하는 Django 미들웨어의 코드 예제에 대한 것입니다. 필요한 친구가 참고할 수 있기를 바랍니다.

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(&#39;操作过于频繁&#39;)
            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

위 내용은 사용자 인증 및 IP 빈도 제한을 구현하는 Django 미들웨어의 코드 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제