限制访问次数例子和Ajax的some
-- 限制访问次数作业解答 --
-- urls.py 里--
from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),] -- views.py 里--
from django.shortcuts import render, HttpResponse
def index(request):
return HttpResponse('index') -- 代码写在哪里? 限制次数 --
新建文件夹 middleware --> my_middleware.py里
在 settings.py 里注册中间件 'middleware.my_middleware.Throttle'
导入类
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import HttpResponse
import time visit_dict = {}
-- 普通版 --
class Throttle(MiddlewareMixin): 节流器
def process_request(self, request):
ip = request.META.get('REMOTE_ADDR')
now = time.time()
# 获取访问的记录
history = visit_dict.get(ip, [])
# 根据记录进行判断 [ 10:06:05,10:06:09,10:06:45 ]
new = []
for i in history:
if now - i < 5:
new.append(i)
history = new
if len(history) >= 3:
return HttpResponse('访问频率太快了,你先歇一会')
history.append(now)
visit_dict[ip] = history -- 优化版--
def process_request(self, request):
ip = request.META.get('REMOTE_ADDR')
now = time.time()
# 获取访问的记录
history = visit_dict.get(ip, [])
# 根据记录进行判断 [ 10:06:45,10:06:09,10:06:05, ]
while history and now - history[-1] > 5:
history.pop() #删除最后一个
if len(history) >= 3:
return HttpResponse('访问频率太快了,你先歇一会')
history.insert(0, now)
visit_dict[ip] = history
-- session 版 -- 一个浏览器就是一个用户
def process_request(self, request):
now = time.time() #拿到当前时间
# 获取访问的记录
history = request.session.get('history', [])
# 根据记录进行判断 [ 10:06:45,10:06:09,10:06:05, ]
while history and now - history[-1] > 5:
history.pop()
if len(history) >= 3:
return HttpResponse('访问频率太快了,你先歇一会')
history.insert(0, now)
request.session['history'] = history
数据库没表 python manage.py migrate 数据库迁移命令
django_session表 一个浏览器就是一个记录
-- html -- ajax参数的问题
$.ajax({
url: '/ajax_test/', 提交地址
type: 'get', 类型
data: { 数据
name: 'alex', 键值对
age: 73,
hobby: JSON.stringify(['大保健', 'cnb', '画大饼'])
},
success: function (res) { 回调函数
console.log(res)
},
error: function (res) { 错误
console.log(res)
}
}) -- views.py -- from django.conf import global_settings
import json
from django.http import JsonResponse def ajax_test(request): print(request.POST) hobby = request.POST.get('hobby') # 拿到字符串的东西
hobby = json.loads(hobby) # 反序列化
print(hobby, type(hobby)) # 列表 list # return HttpResponse(json.dumps({'xxx':'xxxx'})) # text/html; charset=utf-8
return JsonResponse({'xxx': 'xxxx'}) # content_type: application/json'
# return JsonResponse([],safe=False) # content_type: application/json'
复制代码
上传文件 upload
-- html --
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form action="" enctype="multipart/form-data"></form>
**<form action="" enctype="application/x-www-form-urlencoded"></form>** 删除这行
<input type="file" id="f1">
<button id="b1">上传</button> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
<script>
$('#b1').click(function () {
var form_obj = new FormData(); #组建FormData对象
form_obj.append('x1', $('#f1')[0].files[0]); #jQuery对象到DOM对象--键,值
$.ajax({
url: '/upload/',
type: 'post',
data: form_obj,
processData:false, #注意 不处理编码方式
contentType:false, #注意 不处理请求头
success: function (res) {
alert('OK')
}
})
})
</script>
</body>
</html> -- views.py -- 此时注释csrf中间件
def upload(request):
if request.is_ajax(): #是的话就返回True
file_obj = request.FILES.get('x1')
with open(file_obj.name, 'wb') as f:
for i in file_obj.chunks():
f.write(i)
return HttpResponse('ok')
return render(request, 'upload.html')
csrf 校验
-- 发 ajax 能提交 post 请求 --
保证有cookie {% csrf_token %} 两个作用:一个是隐藏的标签,另一个检查里能看到cookie了
方法一:
$.ajax({
url: '/calc/',
type: 'post',
data: { csrfmiddlewaretoken:$('[name="csrfmiddlewaretoken"]').val() , #属性选择器
i1: $('[name="i1"]').val(),
i2: $('[name="i2"]').val(),
},
success: function (res) {
$('[name="i3"]').val(res)
}
})
方法二:
装饰器
from django.views.decorators.csrf import ensure_csrf_cookie #确保访问某个视图有csrf_cookie
@ensure_csrf_cookie
def func(request):
pass
设置请求头
$('#b2').click(function () {
$.ajax({
url: '/calc2/',
type: 'post',
headers:{
'X-csrftoken': $('[name="csrfmiddlewaretoken"]').val(),
},
data: {
i1: $('[name="ii1"]').val(),
i2: $('[name="ii2"]').val(),
},
success: function (res) {
$('[name="ii3"]').val(res)
}
})
});
推荐以后的用法 -- 引入静态文件,配置静态文件 --批量操作
static --> js -->ajax_setup.js
function getCookie(name) {
var cookieValue = null;
if (document.cookie && document.cookie !== '') {
var cookies = document.cookie.split(';');
for (var i = 0; i < cookies.length; i++) {
var cookie = jQuery.trim(cookies[i]);
// Does this cookie string begin with the name we want?
if (cookie.substring(0, name.length + 1) === (name + '=')) {
cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
break;
}
}
}
return cookieValue;
}
var csrftoken = getCookie('csrftoken');
function csrfSafeMethod(method) {
// these HTTP methods do not require CSRF protection
return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
} #正则表达式 匹配
$.ajaxSetup({
beforeSend: function (xhr, settings) {
if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
xhr.setRequestHeader("X-CSRFToken", csrftoken);
}
}
});
页面引用
<script src="/static/js/ajax_setup.js"></script>
这样每个ajax都可以发送post请求了
限制访问次数例子和Ajax的some的更多相关文章
- 利用 awk 统计nginx 中某一个用户的访问次数
线上总是会遇到攻击,所以就需要分析 access.log 看看那些用户的访问次数不正常,针对这些不正常的用户,要做处理,以 access.log为例说明下怎么统计. 通过 access.log 日志来 ...
- php统计网站访问次数的一个简单方法
这里主要用到了session保存当前访问者,并将访问次数写入本地文件. <? @session_start(); $counter = intval(file_get_contents(&quo ...
- Java web--Filter过滤器分IP统计访问次数
分IP统计访问次数即网站统计每个IP地址访问本网站的次数. 分析 因为一个网站可能有多个页面,无论哪个页面被访问,都要统计访问次数,所以使用过滤器最为方便. 因为需要分IP统计,所以可以在过滤器中创建 ...
- JSP+Servlet+JavaBean统计页面在线访问次数
统计页面浏览次数:使用的是servlet实现统计次数传递给JSP页面 说明:我做的都比较接地气,意思就是比较简单! 效果图如下: 上代码 counter.java(它真的好简单,啥事不干,只是定义一个 ...
- Nginx限制某个IP同一时间段的访问次数
nginx可以通过HttpLimitReqModul和HttpLimitZoneModule配置来限制ip在同一时间段的访问次数. HttpLimitReqModul用来限制连单位时间内连接数的模块, ...
- nginx日志中访问最多的100个ip及访问次数
nginx日志中访问最多的100个ip及访问次数 awk '{print $1}' /opt/software/nginx/logs/access.log| sort | uniq -c | sort ...
- web api 限制单个IP在一定时间内访问次数
ps:下面实例是每隔30秒访问次数不超过3次 1.Filter: using Infrastructure.Log; using Infrastructure.Web; using Lemon.Sta ...
- 学习笔记_过滤器应用_1(分ip统计网站的访问次数)
分ip统计网站的访问次数 ip count 192.168.1.111 2 192.168.1.112 59 统计工作需要在所有资源之前都执行,那么就可以放到Filter中了. 我们这个过滤器不打算做 ...
- Java web 实现 之 Filter分析ip统计网站的访问次数
统计工作需要在所有资源之前都执行,那么就可以放到Filter中了. 我们这个过滤器不打算做拦截操作!因为我们只是用来做统计的. 用什么东西来装载统计的数据.Map<String,Integer& ...
随机推荐
- adb移动端测试
1. Android介绍 Android 是google公司主导的一个开放的手机操作系统,不过目前已经超过了手机的局限,而定位于移动设备的操作系统. Android一词的本义指“机器人”,取名原因很简 ...
- Visual Studio使用Web Deploy远程发布网站及其配置
https://blog.csdn.net/yzj_xiaoyue/article/details/60574378 废话不多说,直接进入正题(各个步骤请看图片的序号): IIS配置 1.打开服务器 ...
- warning: LF will be replaced by CRLF in 解决办法
今天用Git bash遇到的问题,看了几个回答之后发现一个比较有价值的,给大家分享一下,其他很多的回答都有很或多或少存在一些弊端. 原回答地址在stackoverflow上,附上链接--http:// ...
- 设置 matlab 画图格式
1:设置 matlab 画图格式 clear;clc; % load("array.mat"); % Bestallarray=array; % rllofcircle(Besta ...
- jenkins 邮箱配置---腾讯企业邮箱
一,简单设置 1.登陆jenkins--> 系统管理 ---> 系统设置 2.邮箱就是发送者的邮箱,密码是登陆邮箱的密码 3.设置完以后,可以点击‘test configuration’, ...
- Dotfuscator 使用图解教程
Dotfuscator:是.NET混淆器和压缩器,它可以帮助您防止您的应用程序被反编译.同时,它还可以使得您的应用程序更加小巧以及高效.我用的是4.9版本的Dotfuscator,Dotfuscato ...
- cocos JS for循环让精灵从屏幕中间往两边排列散开
//this.ShowImg[i] 需要排列什么就push加进数组里面,一个for循环计算即可 var size = this.ShowImg.length;var count = size; for ...
- 巧用CurrentThread.Name来统一标识日志记录(完结篇)
▄︻┻┳═一Agenda: ▄︻┻┳═一巧用CurrentThread.Name来统一标识日志记录 ▄︻┻┳═一巧用CurrentThread.Name来统一标识日志记录(续) ▄︻┻┳═一巧用Cur ...
- Asp.netCore之安装centos7 资料收集
虚拟机的安装和centos的安装看博友的文章:https://www.cnblogs.com/zhaopei/p/netcore.html ifconfig 在centons中用终端写命令比较费劲,可 ...
- 图像中的stride含义
这个不是卷积中的步长stride 是另外一个含义, stride = 每个像素所占字节数 * width input stride为我们正常进行卷积时候设置的stride值,output stride ...