网页制作之CSRF安全验证

学习目标:

理解CSRF工作原理,能够建立完整CSRF流程。

学习内容:

1、CSRF原理
在用户进行post提交数据时,先要经过CSRF中间件进行安全验证,验证通过后才通过路由找到对应的view视图函数进行操作。

2、 创建CSRF流程

-	解除settings文件中对CSRF中间件的注释
	MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
-	在模板文件中加入CSRFtoken设置
		方法一:直接在form表单中添加代码
			<form action="/login/" method="post">
		        {% csrf_token %}
		        <label>
		            用户名:<input type="text" name="username"/>
		        </label>
		        <input type="submit" value="提交"/>
	    	</form>
    	方法二:通过AjaxSetup进行设置
    		<form action="/login/" method="post">
		        <label>
		            用户名:<input type="text" name="username"/>
		        </label>
		        <input type="submit" value="提交"/>
		    </form>
		    <script src="/static/jquery-1.12.4.js"></script>
		    <script src="/static/jquery.cookie.js"></script>
		    <script>
		        $(function () {
		            $.ajaxSetup({
		                beforeSend:function (xhr,settings) {
		                    xhr.setRequestHeader("X-CSRFtoken",$.cookie("csrftoken"))
		                }
		            });
		        });
		    </script>
	    方法三:通过Ajax设置点击函数
	    	<form action="/login/" method="post">
		        <label>
		            用户名:<input type="text" name="username"/>
		        </label>
		        <div>
		            <input id="btn" type="button" value="CSRF"/>
		        </div>
		        <input type="submit" value="提交"/>
		    </form>
		    <script src="/static/jquery-1.12.4.js"></script>
		    <script src="/static/jquery.cookie.js"></script>
		    <script>
		            $("#btn").click(function () {
		                $.ajax({
		                    url:"/login/",
		                    method:"POST",
		                    data:{"username":"root","pwd":123},
		                    headers:{"X-CSRFtoken":$.cookie("csrftoken")},
		                    success:function (arg) {
		
		                    }
		                })
		            })
		        });
		    </script>
-	其他地方无需改动

3、定制性设置CSRF安全验证

-	在view函数中导入csrf_exempt,csrf_protect
	from django.views.decorators.csrf import csrf_exempt,csrf_protect
-	对需要保护的函数进行装饰器设置
	@csrf_protect
	def index(request):
		pass
-	对无需保护的函数进行装饰器设置
	@csrf_exempt
	def index(request):
		pass

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值