django使用ajax过程中遇到的问题

本文介绍了在Django中使用Ajax时遇到的csrf_token问题和数据传输问题。对于csrf_token,无论传输字典还是标准JSON格式,都需要考虑验证。在传输数据方面,字典格式可以直接发送,而JSON格式需要预处理,包括添加csrf验证,使用JSON.stringify()转换为字符串,后端通过request.body接收并用json.loads()解码成Python对象。
摘要由CSDN通过智能技术生成

一、csrf_token问题

使用post请求时,需要加csrf验证

(一)如果传输的是字典格式,则在字典中添加一项

'csrfmiddlewaretoken': $("[name='csrfmiddlewaretoken']").val()

或者

'csrfmiddlewaretoken':'{
  { csrf_token }}'

(二)如果传输的是标准json格式,则可在头部添加csrf验证

$.ajax({
	url:'sum/',
	dataType:'json',
	type:'post',
	contentType:'application/json',
	headers:{"X-CSRFToken":$.cookie('csrftoken')},//此种方法需要script一个jq的cookie插件
        //或者headers:{"X-CSRFToken":getCookie('csrftoken')}
        ...
        })

二、ajax向后端传输数据问题

(一)字典格式

var data = {'csrfmiddlewaretoken': $("[name='csrfmiddlewaretoken
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值