【问题标题】:AngularJs $http.post() does not send dataAngularJs $http.post() 不发送数据
【发布时间】:2013-10-15 17:59:16
【问题描述】:

谁能告诉我为什么下面的语句没有将post数据发送到指定的url?当我打印 $_POST 时,该 url 被调用但在服务器上 - 我得到一个空数组。如果我在将消息添加到数据之前在控制台中打印消息 - 它会显示正确的内容。

$http.post('request-url',  { 'message' : message });

我也尝试过将数据作为字符串(结果相同):

$http.post('request-url',  "message=" + message);

当我以以下格式使用它时,它似乎正在工作:

$http({
    method: 'POST',
    url: 'request-url',
    data: "message=" + message,
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
});

但是有没有办法用 $http.post() 来做 - 我是否总是必须包含标题才能让它工作?我相信上面的内容类型是指定发送数据的格式,但我可以将它作为 javascript 对象发送吗?

【问题讨论】:

  • url是否同源?
  • 抱歉 - 是的,所有示例都是相同的 url
  • @SpencerMark 对不起..我在你的工作代码上面试过..它不适合我。

标签: angularjs post angular-http


【解决方案1】:

我在使用 asp.net MVC 和 found the solution here时遇到了同样的问题

AngularJS 的新手对于为什么 $http 服务速记函数($http.post() 等)似乎没有 可与 jQuery 等价物(jQuery.post() 等)进行交换

区别在于 jQueryAngularJS 如何序列化和传输数据。从根本上说,问题在于您选择的服务器语言无法原生地理解 AngularJS 的传输……默认情况下,jQuery 使用

传输数据
Content-Type: x-www-form-urlencoded

还有熟悉的foo=bar&baz=moe序列化。

然而,

AngularJS 使用

传输数据
Content-Type: application/json 

{ "foo": "bar", "baz": "moe" }

JSON 序列化,不幸的是某些 Web 服务器语言——尤其是 PHP——不要本机反序列化。

像魅力一样工作。

代码

// Your app's root module...
angular.module('MyModule', [], function($httpProvider) {
  // Use x-www-form-urlencoded Content-Type
  $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8';

  /**
   * The workhorse; converts an object to x-www-form-urlencoded serialization.
   * @param {Object} obj
   * @return {String}
   */ 
  var param = function(obj) {
    var query = '', name, value, fullSubName, subName, subValue, innerObj, i;

    for(name in obj) {
      value = obj[name];

      if(value instanceof Array) {
        for(i=0; i<value.length; ++i) {
          subValue = value[i];
          fullSubName = name + '[' + i + ']';
          innerObj = {};
          innerObj[fullSubName] = subValue;
          query += param(innerObj) + '&';
        }
      }
      else if(value instanceof Object) {
        for(subName in value) {
          subValue = value[subName];
          fullSubName = name + '[' + subName + ']';
          innerObj = {};
          innerObj[fullSubName] = subValue;
          query += param(innerObj) + '&';
        }
      }
      else if(value !== undefined && value !== null)
        query += encodeURIComponent(name) + '=' + encodeURIComponent(value) + '&';
    }

    return query.length ? query.substr(0, query.length - 1) : query;
  };

  // Override $http service's default transformRequest
  $httpProvider.defaults.transformRequest = [function(data) {
    return angular.isObject(data) && String(data) !== '[object File]' ? param(data) : data;
  }];
});

【讨论】:

  • 我已将此脚本添加到 bower,请使用 bower install angular-post-fix --save-dev 添加。
  • 那么有没有办法改变php的传输数据方法。因为这是我目前遇到的问题。
  • 这段代码在大多数情况下都很好用,但是在提交空对象的层次结构甚至是空值时我遇到了问题。例如 { a: 1, b: { c: { d: { } } }, e: undefined, f: null, g: 2 } 将无法正确编码,PHP 将其作为 [ "a" = >“1”,“g”=>“2”]。 “b”下的整个结构,以及“e”和“f”,包括键本身——都将丢失。我在下面发布了替代代码,上面的结构被解码为: [ "a" => "1", "b" => [ "c" => [ "d" => "" ] ], "e" => "", "f" => "", "g" => "2" ].
  • 我应该如何为 multipart/form-data 实现这个?
  • 精湛:) 确实像一个魅力。我遇到了 Spring MVC 的问题
【解决方案2】:

上面不是很清楚,但是如果你是在 PHP 中接收请求,你可以使用:

$params = json_decode(file_get_contents('php://input'),true);

从 AngularJS POST 访问 PHP 中的数组。

【讨论】:

  • 当用它覆盖 $_POST 数组时,我需要添加 true 以强制它到数组中。 json_decode(file_get_contents('php://input'), true);
  • @Zalaboza,我同意很难将任何解决方案视为“通用”,但我不同意它是“hacky”--- php.net 声明:“file_get_contents()是将文件内容读入字符串的首选方式。如果您的操作系统支持,它将使用内存映射技术来提高性能。当然,在这种情况下我们没有读取文件,但我们仍然在读取发布的 json 数据。如果您能提供新的答案或提供新的信息来帮助读者(包括我自己)对此做出更好的决定,那就太好了。
【解决方案3】:

您可以像这样设置默认的“Content-Type”:

$http.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded";

关于data 格式:

$http.post 和 $http.put 方法接受任何 JavaScript 对象(或字符串)值作为它们的数据参数。如果 data 是 JavaScript 对象,默认情况下,它将被转换为 JSON 字符串。

尝试使用这种变体

function sendData($scope) {
    $http({
        url: 'request-url',
        method: "POST",
        data: { 'message' : message }
    })
    .then(function(response) {
            // success
    }, 
    function(response) { // optional
            // failed
    });
}

【讨论】:

  • 它似乎不起作用。我刚刚尝试了将数据作为字符串和 : headers: {'Content-Type': 'application/x-www-form-urlencoded'} 的变体 - 这似乎有效,但有没有更好的方法是吗?
  • 如上所述设置默认内容类型,对于数据不要使用 js 对象。使用这样的字符串:'message='+message 为我工作
【解决方案4】:

我也遇到过类似的问题,不知道这是否也有用:https://stackoverflow.com/a/11443066

var xsrf = $.param({fkey: "key"});
$http({
    method: 'POST',
    url: url,
    data: xsrf,
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
})

问候,

【讨论】:

  • 看起来标题是我们需要的唯一更改。谢谢!
  • 谢谢,为我做的 :) 问题是 POST 数据的编码。
【解决方案5】:

我喜欢使用函数将对象转换为 post 参数。

myobject = {'one':'1','two':'2','three':'3'}

Object.toparams = function ObjecttoParams(obj) {
    var p = [];
    for (var key in obj) {
        p.push(key + '=' + encodeURIComponent(obj[key]));
    }
    return p.join('&');
};

$http({
    method: 'POST',
    url: url,
    data: Object.toparams(myobject),
    headers: {'Content-Type': 'application/x-www-form-urlencoded'}
})

【讨论】:

    【解决方案6】:

    终于在 Angular 1.4 中使用 $httpParamSerializerJQLike

    解决了这个问题

    https://github.com/angular/angular.js/issues/6039

    .controller('myCtrl', function($http, $httpParamSerializerJQLike) {
    $http({
      method: 'POST',
      url: baseUrl,
      data: $httpParamSerializerJQLike({
        "user":{
          "email":"wahxxx@gmail.com",
          "password":"123456"
        }
      }),
      headers:
        'Content-Type': 'application/x-www-form-urlencoded'
    })})
    

    【讨论】:

    【解决方案7】:

    我使用jQuery paramAngularJS post 请求。这是一个示例...创建 AngularJS 应用程序模块,其中 myapp 在您的 HTML 代码中使用 ng-app 定义。

    var app = angular.module('myapp', []);
    

    现在让我们创建一个登录控制器并 POST 电子邮件和密码。

    app.controller('LoginController', ['$scope', '$http', function ($scope, $http) {
        // default post header
        $http.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8';
        // send login data
        $http({
            method: 'POST',
            url: 'https://example.com/user/login',
            data: $.param({
                email: $scope.email,
                password: $scope.password
            }),
            headers: {'Content-Type': 'application/x-www-form-urlencoded'}
        }).success(function (data, status, headers, config) {
            // handle success things
        }).error(function (data, status, headers, config) {
            // handle error things
        });
    }]);
    

    我不喜欢解释代码,它很容易理解:) 请注意param 来自 jQuery,因此您必须同时安装 jQuery 和 AngularJS 才能使其工作。这是截图。

    希望这会有所帮助。谢谢!

    【讨论】:

      【解决方案8】:

      我在使用 AngularJS 和 Node.js + Express 4 + 路由器时遇到了同样的问题

      Router 期望来自 post 请求的数据在 body 中。如果我按照 Angular Docs 中的示例进行操作,此正文始终为空

      符号 1

      $http.post('/someUrl', {msg:'hello word!'})
      

      但如果我在数据中使用它

      符号 2

      $http({
             withCredentials: false,
             method: 'post',
             url: yourUrl,
             headers: {'Content-Type': 'application/x-www-form-urlencoded'},
             data: postData
       });
      

      编辑 1:

      否则,如果使用符号 1,node.js 路由器将期望 req.body 中的数据:

      req.body.msg
      

      它还将信息作为 JSON 有效负载发送。这在某些情况下会更好,因为您的 json 中有数组并且 x-www-form-urlencoded 会产生一些问题。

      成功了。希望对您有所帮助。

      【讨论】:

        【解决方案9】:

        与 JQuery 不同,为了迂腐,Angular 使用 JSON 格式进行 POST 数据 transfer 从客户端到服务器(JQuery 大概应用 x-www-form-urlencoded,尽管 JQuery 和 Angular 使用 JSON 进行数据输入)。因此有两个部分的问题:在 js 客户端部分和您的服务器部分。所以你需要:

        1. 将 js Angular 客户端部分如下:

          $http({
          method: 'POST',
          url: 'request-url',
          data: {'message': 'Hello world'}
          });
          

        1. 写入服务器部分以从客户端接收数据(如果是 php)。

                  $data               = file_get_contents("php://input");
                  $dataJsonDecode     = json_decode($data);
                  $message            = $dataJsonDecode->message;
                  echo $message;     //'Hello world'
          

        注意:$_POST 不起作用!

        该解决方案对我来说很好,希望对你有用。

        【讨论】:

          【解决方案10】:

          以@felipe-miosso 的回答为基础:

          1. here下载它作为AngularJS模块,
          2. 安装它
          3. 将其添加到您的应用程序中:

            var app = angular.module('my_app', [ ... , 'httpPostFix']);
            

          【讨论】:

            【解决方案11】:

            要使用 $http 的 angularjs 通过 Post 方法发送数据,您需要更改

            data: "message=" + message,与data: $.param({message:message})

            【讨论】:

            • 为什么发送AngularJS post数据时需要data: $.param?
            【解决方案12】:

            我没有评论的声誉,但响应/补充唐 F 的回答:

            $params = json_decode(file_get_contents('php://input'));

            true 的第二个参数需要添加到json_decode 函数中才能正确返回关联数组:

            $params = json_decode(file_get_contents('php://input'), true);

            【讨论】:

              【解决方案13】:

              角度

                var payload = $.param({ jobId: 2 });
              
                              this.$http({
                                  method: 'POST',
                                  url: 'web/api/ResourceAction/processfile',
                                  data: payload,
                                  headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
                              });
              

              WebAPI 2

              public class AcceptJobParams
                      {
                          public int jobId { get; set; }
                      }
              
                      public IHttpActionResult ProcessFile([FromBody]AcceptJobParams thing)
                      {
                          // do something with fileName parameter
              
                          return Ok();
                      }
              

              【讨论】:

                【解决方案14】:

                这段代码为我解决了这个问题。它是一个应用级的解决方案:

                moduleName.config(['$httpProvider',
                  function($httpProvider) {
                    $httpProvider.defaults.transformRequest.push(function(data) {
                        var requestStr;
                        if (data) {
                            data = JSON.parse(data);
                            for (var key in data) {
                                if (requestStr) {
                                    requestStr += "&" + key + "=" + data[key];
                                } else {
                                    requestStr = key + "=" + data[key];
                                }
                            }
                        }
                        return requestStr;
                    });
                    $httpProvider.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded";
                  }
                ]);
                

                【讨论】:

                  【解决方案15】:

                  在你的 js 文件中添加这个:

                  $http.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded";
                  

                  并将其添加到您的服务器文件中:

                  $params = json_decode(file_get_contents('php://input'), true);
                  

                  应该可以的。

                  【讨论】:

                    【解决方案16】:

                    我也遇到了类似的问题,我正在做这样的事情,但没有奏效。我的 Spring 控制器无法读取数据参数。

                    var paramsVal={data:'"id":"1"'};
                      $http.post("Request URL",  {params: paramsVal});  
                    

                    但是阅读这个论坛和 API 文档,我尝试了以下方式,这对我有用。 如果有人也有类似的问题,你也可以试试下面的方法。

                    $http({
                          method: 'POST',
                          url: "Request URL",           
                          params: paramsVal,
                          headers: {'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'}
                                });
                    

                    请查看https://docs.angularjs.org/api/ng/service/$http#post 了解 param config 的作用。 {data:'"id":"1"'} – 将转换为 URL 的字符串或对象的映射?data="id:1"

                    【讨论】:

                      【解决方案17】:

                      这可能是一个迟到的答案,但我认为最合适的方法是在使用您$httpParamSerializer 进行“获取”请求时使用相同的代码角度使用将不得不将其注入您的控制器 所以您可以简单地执行以下操作,而无需使用 Jquery, $http.post(url,$httpParamSerializer({param:val}))

                      app.controller('ctrl',function($scope,$http,$httpParamSerializer){
                          $http.post(url,$httpParamSerializer({param:val,secondParam:secondVal}));
                      }
                      

                      【讨论】:

                        【解决方案18】:

                        就我而言,我这样解决问题:

                        var deferred = $q.defer();
                        
                        $http({
                            method: 'POST',
                            url: 'myUri', 
                            data: $.param({ param1: 'blablabla', param2: JSON.stringify(objJSON) }),
                            headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
                        }).then(
                            function(res) {
                                console.log('succes !', res.data);
                                deferred.resolve(res.data);
                            },
                            function(err) {
                                console.log('error...', err);
                                deferred.resolve(err);
                            }
                        );
                        return deferred.promise;
                        

                        您需要为每个包含 JSON 对象的参数使用 JSON.stringify,然后使用 "$.param" 构建您的数据对象 :-)

                        注意:我的“objJSON”是一个 JSON 对象,包含数组、整数、字符串和 html 内容。他的总大小超过 3500 个字符。

                        【讨论】:

                          【解决方案19】:

                          我知道有接受答案。但是,如果答案因任何原因不适合他们,以下内容可能会对未来的读者有所帮助。

                          Angular 不像 jQuery 那样做 ajax。当我尝试按照指南修改角度 $httpprovider 时,我遇到了其他问题。例如。我使用 codeigniter,其中 $this-&gt;input-&gt;is_ajax_request() 函数总是失败(由另一个程序员编写并在全局范围内使用,因此无法更改)说这不是真正的 ajax 请求。

                          为了解决这个问题,我求助于deferred promise。我在 Firefox 和 ie9 中测试了它,它工作正常。

                          我在任何角度代码外部定义了以下函数。此函数进行常规 jquery ajax 调用并返回 deferred/promise(我还在学习)对象。

                          function getjQueryAjax(url, obj){
                              return $.ajax({
                                  type: 'post',
                                  url: url,
                                  cache: true,
                                  data: obj
                              });
                          }
                          

                          然后我使用以下代码将其称为角度代码。请注意,我们必须使用 $scope.$apply() 手动更新 $scope

                              var data = {
                                  media: "video",
                                  scope: "movies"
                              };
                              var rPromise = getjQueryAjax("myController/getMeTypes" , data);
                              rPromise.success(function(response){
                                  console.log(response);
                                  $scope.$apply(function(){
                                      $scope.testData = JSON.parse(response);
                                      console.log($scope.testData);
                                  });
                              }).error(function(){
                                  console.log("AJAX failed!");
                              });
                          

                          这可能不是完美的答案,但它允许我使用 angular 的 jquery ajax 调用并允许我更新$scope

                          【讨论】:

                          • Angular 从 1.3 开始就有自己的承诺服务,称为 $q。无需使用 JQuery 来发帖。
                          【解决方案20】:

                          我在 express 中遇到了同样的问题 .. 要解决您必须在发送 http 请求之前使用 bodyparser 解析 json 对象..

                          app.use(bodyParser.json());
                          

                          【讨论】:

                            【解决方案21】:

                            我正在使用带有角度 js 和以下代码的 asp.net WCF webservices 工作:

                             $http({
                                    contentType: "application/json; charset=utf-8",//required
                                    method: "POST",
                                    url: '../../operation/Service.svc/user_forget',
                                    dataType: "json",//optional
                                    data:{ "uid_or_phone": $scope.forgettel, "user_email": $scope.forgetemail },
                                    async: "isAsync"//optional
                            
                                   }).success( function (response) {
                            
                                     $scope.userforgeterror = response.d;                    
                                   })
                            

                            希望对你有帮助。

                            【讨论】:

                              【解决方案22】:

                              没有找到完整的代码 sn-p 说明如何使用 $http.post 方法向服务器发送数据以及为什么在这种情况下它不起作用。

                              下面代码sn-p的解释...

                              1. 我正在使用 jQuery $.param 函数将 JSON 数据序列化为 www post 数据
                              2. 在配置变量中设置 Content-Type,该变量将与 angularJS $http.post 的请求一起传递,指示服务器我们正在以 www post 格式发送数据。

                              3. 注意 $htttp.post 方法,我将第一个参数作为 url,第二个参数作为数据(序列化)和第三个参数作为配置发送。

                              其余代码自行理解。

                              $scope.SendData = function () {
                                         // use $.param jQuery function to serialize data from JSON 
                                          var data = $.param({
                                              fName: $scope.firstName,
                                              lName: $scope.lastName
                                          });
                              
                                          var config = {
                                              headers : {
                                                  'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8;'
                                              }
                                          }
                              
                                          $http.post('/ServerRequest/PostDataResponse', data, config)
                                          .success(function (data, status, headers, config) {
                                              $scope.PostDataResponse = data;
                                          })
                                          .error(function (data, status, header, config) {
                                              $scope.ResponseDetails = "Data: " + data +
                                                  "<hr />status: " + status +
                                                  "<hr />headers: " + header +
                                                  "<hr />config: " + config;
                                          });
                                      };
                              

                              $http.post method here的代码示例。

                              【讨论】:

                                【解决方案23】:

                                如果您使用 PHP,这是一种从 AngularJS POST 访问 PHP 数组的简单方法。

                                $params = json_decode(file_get_contents('php://input'),true);
                                

                                【讨论】:

                                【解决方案24】:

                                如果使用 Angular >= 1.4,这是使用 the serializer provided by Angular 的最干净的解决方案:

                                angular.module('yourModule')
                                  .config(function ($httpProvider, $httpParamSerializerJQLikeProvider){
                                    $httpProvider.defaults.transformRequest.unshift($httpParamSerializerJQLikeProvider.$get());
                                    $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded; charset=utf-8';
                                });
                                

                                然后您可以在应用中的任何位置简单地执行此操作:

                                $http({
                                  method: 'POST',
                                  url: '/requesturl',
                                  data: {
                                    param1: 'value1',
                                    param2: 'value2'
                                  }
                                });
                                

                                它会正确地将数据序列化为param1=value1&amp;param2=value2,并使用application/x-www-form-urlencoded; charset=utf-8 Content-Type 标头将其发送到/requesturl,这在端点上的POST请求中通常是预期的。

                                TL;DR

                                在我的研究中,我发现这个问题的答案有很多种;有些非常复杂,依赖于自定义函数,有些依赖于 jQuery,有些则不完整,建议您只需要设置标题。

                                如果您只是设置Content-Type 标头,端点将看到 POST 数据,但它不会是标准格式,因为除非您提供一个字符串作为您的data,或者手动序列化您的数据对象,默认全部序列化为JSON,可能在端点被错误解释。

                                例如如果在上面的示例中没有设置正确的序列化程序,它将在端点中被视为:

                                {"param1":"value1","param2":"value2"}
                                

                                这可能会导致意外的解析,例如ASP.NET 将其视为null 参数名称,以{"param1":"value1","param2":"value2"} 为值;或者 Fiddler 以另一种方式解释它,{"param1":"value1","param2":"value2"} 作为参数名称,null 作为值。

                                【讨论】:

                                  【解决方案25】:

                                  类似于 OP 建议的工作格式和丹尼森的回答,除了使用 $http.post 而不是仅使用 $http 并且仍然依赖于 jQuery。

                                  在这里使用 jQuery 的好处是可以正确传递复杂的对象;反对手动转换成可能造成数据乱码的URL参数。

                                  $http.post( 'request-url', jQuery.param( { 'message': message } ), {
                                      headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
                                  });
                                  

                                  【讨论】:

                                    【解决方案26】:

                                    只需将您要发送的数据作为第二个参数:

                                    $http.post('request-url',  message);
                                    

                                    另一种同样有效的形式是:

                                    $http.post('request-url',  { params: { paramName: value } });
                                    

                                    确保paramName 与您正在调用的函数的参数名称完全匹配。

                                    来源:AngularJS post shortcut method

                                    【讨论】:

                                    【解决方案27】:

                                    当我遇到这个问题时,我发布的参数原来是一个对象数组而不是一个简单的对象。

                                    【讨论】:

                                      【解决方案28】:

                                      刚从angular 1.2更新到1.3,发现代码有问题。转换资源将导致无限循环,因为(我认为) $promise 再次持有同一个对象。也许它会帮助某人......

                                      我可以通过以下方式解决这个问题:

                                      [...]
                                        /**
                                       * The workhorse; converts an object to x-www-form-urlencoded serialization.
                                       * @param {Object} obj
                                       * @return {String}
                                       */
                                      var param = function (obj) {
                                      var query = '', name, value, fullSubName, subName, subValue, innerObj, i;
                                      
                                      angular.forEach(obj, function(value, name) {
                                      +    if(name.indexOf("$promise") != -1) {
                                      +        return;
                                      +    }
                                      
                                          value = obj[name];
                                          if (value instanceof Array) {
                                              for (i = 0; i < value.length; ++i) {
                                      [...]
                                      

                                      【讨论】:

                                        【解决方案29】:

                                        我已经使用接受的答案代码(Felipe 的代码)有一段时间了,效果很好(谢谢,Felipe!)。

                                        但是,最近我发现它存在空对象或数组的问题。 比如提交这个对象的时候:

                                        {
                                            A: 1,
                                            B: {
                                                a: [ ],
                                            },
                                            C: [ ],
                                            D: "2"
                                        }
                                        

                                        PHP 似乎根本看不到 B 和 C。它得到了这个:

                                        [
                                            "A" => "1",
                                            "B" => "2"
                                        ]
                                        

                                        查看 Chrome 中的实际请求表明:

                                        A: 1
                                        :
                                        D: 2
                                        

                                        我写了一个替代代码sn-p。它似乎适用于我的用例,但我尚未对其进行广泛测试,因此请谨慎使用。

                                        我使用 TypeScript 是因为我喜欢强类型,但它很容易转换为纯 JS:

                                        angular.module("MyModule").config([ "$httpProvider", function($httpProvider: ng.IHttpProvider) {
                                            // Use x-www-form-urlencoded Content-Type
                                            $httpProvider.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded;charset=utf-8";
                                        
                                            function phpize(obj: Object | any[], depth: number = 1): string[] {
                                                var arr: string[] = [ ];
                                                angular.forEach(obj, (value: any, key: string) => {
                                                    if (angular.isObject(value) || angular.isArray(value)) {
                                                        var arrInner: string[] = phpize(value, depth + 1);
                                                        var tmpKey: string;
                                                        var encodedKey = encodeURIComponent(key);
                                                        if (depth == 1) tmpKey = encodedKey;
                                                        else tmpKey = `[${encodedKey}]`;
                                                        if (arrInner.length == 0) {
                                                            arr.push(`${tmpKey}=`);
                                                        }
                                                        else {
                                                            arr = arr.concat(arrInner.map(inner => `${tmpKey}${inner}`));
                                                        }
                                                    }
                                                    else {
                                                        var encodedKey = encodeURIComponent(key);
                                                        var encodedValue;
                                                        if (angular.isUndefined(value) || value === null) encodedValue = "";
                                                        else encodedValue = encodeURIComponent(value);
                                        
                                                        if (depth == 1) {
                                                            arr.push(`${encodedKey}=${encodedValue}`);
                                                        }
                                                        else {
                                                            arr.push(`[${encodedKey}]=${encodedValue}`);
                                                        }
                                                    }
                                                });
                                                return arr;
                                            }
                                        
                                            // Override $http service's default transformRequest
                                            (<any>$httpProvider.defaults).transformRequest = [ function(data: any) {
                                                if (!angular.isObject(data) || data.toString() == "[object File]") return data;
                                                return phpize(data).join("&");
                                            } ];
                                        } ]);
                                        

                                        它的效率不如 Felipe 的代码,但我认为这并不重要,因为与 HTTP 请求本身的总体开销相比,它应该是即时的。

                                        现在 PHP 显示:

                                        [
                                            "A" => "1",
                                            "B" => [
                                                "a" => ""
                                            ],
                                            "C" => "",
                                            "D" => "2"
                                        ]
                                        

                                        据我所知,让 PHP 识别 Ba 和 C 是空数组是不可能的,但至少会出现键,这在存在依赖于特定结构的代码时很重要,即使它内部基本上是空的.

                                        另请注意,它将 undefineds 和 nulls 转换为空字符串。

                                        【讨论】:

                                        • TypeScript 是使用 JavaScript 在 POO 中编码的最佳方式!
                                        【解决方案30】:

                                        我通过以下代码解决了这个问题:

                                        客户端(Js):

                                             $http({
                                                        url: me.serverPath,
                                                        method: 'POST',
                                                        data: data,
                                                        headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
                                                    }).
                                                        success(function (serverData) {
                                                            console.log("ServerData:", serverData);
                                            ......
                                        

                                        注意 data 是一个对象。

                                        在服务器上(ASP.NET MVC):

                                        [AllowCrossSiteJson]
                                                public string Api()
                                                {
                                                    var data = JsonConvert.DeserializeObject<AgentRequest>(Request.Form[0]);
                                                    if (data == null) return "Null Request";
                                                    var bl = Page.Bl = new Core(this);
                                        
                                                    return data.methodName;
                                                }
                                        

                                        跨域请求需要“AllowCrossSiteJsonAttribute”:

                                        public class AllowCrossSiteJsonAttribute : ActionFilterAttribute
                                            {
                                                public override void OnActionExecuting(ActionExecutingContext filterContext)
                                                {
                                                    filterContext.RequestContext.HttpContext.Response.AddHeader("Access-Control-Allow-Origin", "*");
                                                    base.OnActionExecuting(filterContext);
                                                }
                                            }
                                        

                                        希望这是有用的。

                                        【讨论】:

                                          猜你喜欢
                                          • 1970-01-01
                                          • 2023-03-31
                                          • 2017-04-30
                                          • 2017-07-05
                                          • 2017-02-06
                                          • 1970-01-01
                                          • 1970-01-01
                                          • 1970-01-01
                                          • 1970-01-01
                                          相关资源
                                          最近更新 更多