python django post提交出现403

为视图函数添加修饰器(局部禁用)

导入模块

from django.views.decorators.csrf import csrf_exempt

在函数前面添加修饰器

@csrf_exempt
def index(request):
	if request.method == 'GET':
		return render(request,'index.html')
	if request.method == 'POST':
		username = request.POST.get('username')
		password = request.POST.get('password')
		if username == 'admin' and password == 'admin123':
			return redirect('http://www.baidu.com')
		else:
			return render(request,'index.html',{'msg' : '登录失败'})

为表单添加csrf_token验证

<form action="/index/" method="post">
		{% csrf_token %}
		用户名:<input type="text" autocomplete="off" placeholder="请输入用户名" name="username">		
		密码:<input type="password" autocomplete="off" placeholder="请输入密码" name="password">		
		<input type="submit" value="登录">
	</form>

在settings.py设置(全局禁用)

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',
]

AJAX使用

在模板文件中添加

$.ajaxSetup({
    data: {csrfmiddlewaretoken: '{{ csrf_token }}' },
});

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值