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

最新文章

  1. android 测试 Monkey 和 MonkeyRunner 的使用
  2. = splice
  3. Java类加载器深入探索
  4. Google 宣布支持中文邮箱地址
  5. Linux基本命令(8)网络操作的命令
  6. 关于使用Transaction对于非数据库事务的操作
  7. UI4_UIToolBar
  8. 一周一话题之一(EF-CodeFirst、MEF、T4框架搭建学习)
  9. oracle数据库存储过程中NO_DATA_FOUND不起作用?
  10. 第二次项目冲刺(Beta阶段)5.19
  11. 《java入门第一季》之类(String类常见方法小叙)
  12. 【EXCEL-折线图】百折不挠 | 用EXCEL画出与众不同的折线图(曲线图)
  13. Python基础之迭代器和生成器
  14. [Docker] sh: docker-compose: not found
  15. SpringCloud系列十一:SpringCloudStream(SpringCloudStream 简介、创建消息生产者、创建消息消费者、自定义消息通道、分组与持久化、设置 RoutingKey)
  16. spring @Bean注解的使用
  17. java开发定时任务执行时间
  18. Divide the Sequence (贪心)
  19. csharp:SMO run sql script
  20. tensorflow 笔记8:RNN、Lstm源码,训练代码输入输出,维度分析

热门文章

  1. Mac下显示和隐藏“隐藏文件”
  2. animal与@keyframe
  3. Git远程库
  4. C语言实现数组逆置
  5. rocketmq sql解析过滤
  6. 转 crs damon can&#39;t start 2个例子
  7. RabbitMQ---初识
  8. 我的Python升级打怪之路【一】:python的简单认识
  9. Android AsyncTask异步加载WebAPI
  10. orcale 之数据操作