我在AngularJS中有这个代码:
myApp.controller('LoginCtrl', function($scope, $http){
$scope.formData = {};
$scope.doLogin = function(url, pass){
$http({
url: url,
method: "POST",
data: $.param($scope.formData)
}).success(function(data) {
console.log(data)
});
}
});
在后端(Flask),我有这个:
def user_authenticate():
login = request.args.get('login')
password = request.args.get('password')
print login, password
问题是request.args为空。
答案 0 :(得分:9)
<强>更新强>
在遇到很多问题后,我解决了另一个Stackoverflow的问题。所以,我得到了这段代码:
<强> ANGULARJS 强>
$scope.doLogin = function(url, pass){
$http({
url: url,
method: "POST",
headers: { 'Content-Type': 'application/json' },
data: JSON.stringify(data)
}).success(function(data) {
console.log(data)
});
}
<强> FLASK 强>
def view_of_test():
post = request.get_json()
param = post.get('param_name')
OLD VERSION
我只是认为我需要将代码更改为:
AngularJS:
myApp.controller('LoginCtrl', function($scope, $http){
$scope.formData = {};
$scope.doLogin = function(url, pass){
$http({
url: url,
method: "POST",
data: $.param($scope.formData),
headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
}).success(function(data) {
console.log(data)
});
}
});
只需添加“内容类型”标题即可。
烧瓶中:
def user_authenticate():
login = request.form.get('login')
password = request.form.get('password')
print login, password
请使用request.form。
,而不是使用request.args