使用Angularjs发送POST请求并在Flask后端获取参数

时间:2014-04-19 16:04:20

标签: python angularjs flask

我在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为空。

1 个答案:

答案 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