Django ajax请求 403错误

网站使用Django+layui,在向后台发送数据请求需要传递一个数组,使用layui.table的动态渲染,貌似不能实现。无法传递数组信息到views后台的接口。然后根据网络搜索得知可以使用ajax进行post传递数组,但又因为csrf_protected,接口总是返回403错误,尝试了几个方案都无法搞定,最后根据Django csrf文档说明在ajax post请求里添加头部信息,最后实现。

//获取csrftoken
	function getCookie(name) {
    	let cookieValue = null;
    	if (document.cookie && document.cookie !== '') {
        	const cookies = document.cookie.split(';');
        	for (let i = 0; i < cookies.length; i++) {
            	const cookie = cookies[i].trim();
            	// 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;
	}
	const csrftoken = getCookie('csrftoken');
	
//ajax请求
$.ajax({
                url : "/make_match_result",
                type : "post",
                headers: {"X-CSRFToken": csrftoken},
                traditional : true,// 这里设置为true,不然后台接收到的参数会带上[],导致数据无法正常接收
                data : {
                    "scl_nms" : snms,
                    "maj_nms" : mnms
                },
                success : function(resp) {
                	if(resp.code == 0) {
                		console.log('sucess')

                		var tdata = resp.data;
                		console.log(tdata)
                		table.render({
    						elem: '#res_tbl'
    						,data:tdata
    						,cols: [[
      							{field:'name',  title: '名称', width:180}
      							,{field:'mscore', title: '分数', width:110}
    							]]
    						,height: 800
  							});
                	}else {
                		layer.msg('请求错误');
                	}
                }
            });
#views.py 接口
def make_match_result(request):
    snms = request.POST.getlist('scl_nms')
    mnms = request.POST.getlist('maj_nms')
    #...
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
403错误是HTTP状态码之一,表示服务器拒绝了请求。在你提供的引用中,出现了关于DjangoAjax和Spring安全性的讨论,这些都与ajax请求403错误有关。 一种可能的原因是CSRF(Cross-Site Request Forgery)保护机制。CSRF是一种攻击方式,攻击者利用用户在另一个网站上的身份进行恶意操作。为了防止这种攻击,服务器会要求发送请求时携带有效的CSRF令牌。在Django中,可以通过在表单中添加{% csrf_token %}来解决CSRF问题。但是,当使用Ajax发送请求时,需要手动将CSRF令牌添加到请求头中。 另一种可能的原因是权限问题。服务器可能会对某些请求进行权限验证,如果请求的用户没有足够的权限,则会返回403错误。在你提供的引用中,出现了Spring安全性的讨论,这也可能与403错误有关。 为了解决Ajax请求403错误,你可以尝试以下几种解决办法: 1. 在发送Ajax请求时,手动添加有效的CSRF令牌到请求头中。具体的实现方式取决于你所使用的框架和技术。 2. 确保请求的用户具有足够的权限来执行该请求。可以检查用户角色或权限,并在服务器端进行相应的配置和验证。 3. 检查服务器的安全设置,确保没有被误配置导致请求被拒绝。 请根据你的具体情况选择适合的解决办法,并根据错误提示和日志来进一步排查问题的原因。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值