Ajax 从angularjs向django发送数据
我正在使用Angularjs及其$http模块向Django服务器发送一个POST AJAX请求。以下是一个例子:Ajax 从angularjs向django发送数据,ajax,django,http,angularjs,Ajax,Django,Http,Angularjs,我正在使用Angularjs及其$http模块向Django服务器发送一个POST AJAX请求。以下是一个例子: $http({ method: 'POST', url: '/url/', data: 'test data' }). success(function(data, status, headers, config) { doSomeStuffWhenSuccess(); }); 问题是我在Djang
$http({
method: 'POST',
url: '/url/',
data: 'test data'
}).
success(function(data, status, headers, config) {
doSomeStuffWhenSuccess();
});
问题是我在Django得到了什么。无论我发送什么,数据始终是QueryDict
对象的键,其值始终为空列表
<QueryDict: {u'test data': [u'']}>
我不知道为什么。我错过了什么
我使用几乎默认创建的Django应用程序,只使用默认的中间件。我只创建了一个视图,并在url配置中设置了一个url。Django的版本是1.3。我将angular的$http模块配置为始终发送包含csrf令牌的标头,以满足Django的要求。我相信Django认为您发送的是URL编码的表单,例如key=value&key2=value2 如果您愿意尝试:
$http({
method: 'POST',
url: '/url/',
data: 'test=data'
})
你应该
<QueryDict: {u'test': [u'data']}>
希望这就是您要查找的内容。我使用jQuery param函数解决了这个问题。我认为这是更优雅的解决方案
$http({
method: 'POST',
url: '/url/',
data: $.param({test: data})
})
现在它可以正常工作了。谢谢,这很有效!但是你能解释为什么django认为它的URL编码数据吗?如果可以自定义它?request.GET和request.POST包含预处理的键/值数据-如果需要原始数据(如JSON或纯文本),请尝试:request.raw\u POST\u data
$http({
method: 'POST',
url: '/url/',
data: $.param({test: data})
})