本文摘自php中文网,作者不言,侵删。
本篇文章给大家带来的内容是关于Django中间件实现用户认证与IP频率限制的代码示例,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
1、URL访问过滤
通过装饰器进行用户认证非常方便,但是在添加部分需要认证的功能时,就需要再次添加装饰器,如果通过中间件来实现,就不需要再进行添加的操作.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | 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进行限制,进行拦截.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | 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
|
以上就是Django中间件实现用户认证与IP频率限制的代码示例的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
django框架入门使用1.0
Python字典中的键可以重复吗
bottle源码之headerdict详解
Python如何生成随机数字
Python中找出numpy array数组的最值及其索引方法
Python中根据字符串导入模块module的方法介绍(附代码)
go语言和Python哪个难
“if __name__ == __main__:”有什么作用
Python3中socket套接字相关的问题
Python怎么将列表转为字符串
更多相关阅读请进入《Python》频道 >>
人民邮电出版社
python入门书籍,非常畅销,超高好评,python官方公认好书。
转载请注明出处:木庄网络博客 » Django中间件实现用户认证与IP频率限制的代码示例