django csrf解决办法

本文介绍了在Django中屏蔽CSRF验证的两种方法:在settings中注释中间件、在模板中添加{%csrf_token%}

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文出处:http://www.cppblog.com/momoxiao/archive/2011/10/03/157443.aspx?opt=admin 

在settings里注释掉中间件这一行,可以暂时屏蔽csrf验证,但是这样不安全了.
MIDDLEWARE_CLASSES = (
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    # 'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
)


1 在 templete 中, 为每个 POST form 增加一个 {% csrf_token %} tag. 如下: 
<form> 
    {% csrf_token %} 
</form> 
2 在 view 中, 使用 django.template.RequestContext 而不是 Context. 
render_to_response, 默认使用 Context. 需要改成 RequestContext. 
导入 class: 
from django.template import RequestContext 
给 render_to_response 增加一个参数: 
def your_view(request): 
    ... 
    return render_to_response('template.html', 
          your_key_value, 
          context_instance=RequestContext(request) 
          ) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值