【AngularJS】修改post提交json数据的格式_ $httpProvider配置

修改angular post提交默认格式是json数据的格式,我们如果想用$_Post接收数据的话,那么就得配置$httpProvider

$httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
$httpProvider.defaults.headers.put['Content-Type'] = 'application/x-www-form-urlencoded';

.config(['$httpProvider',
          function ($httpProvider) {
              // Use x-www-form-urlencoded Content-Type
              $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
              $httpProvider.defaults.headers.put['Content-Type'] = 'application/x-www-form-urlencoded';


              // Override $http service's default transformRequest
              $httpProvider.defaults.transformRequest = [function(data)
              {
                  /**
                   * The workhorse; converts an object to x-www-form-urlencoded serialization.
                   * @param {Object} obj
                   * @return {String}
                   */
                  var param = function(obj)
                  {
                      var query = '';
                      var name, value, fullSubName, subName, subValue, innerObj, i;
                      console.log(obj);


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


                          if(value instanceof Array)
                          {
                              console.log("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)
                          {
                               console.log("object");
                              for(subName in value)
                              {


                                  subValue = value[subName];
                                  if(subValue != null){
                                      // fullSubName = name + '[' + subName + ']';
                                      //user.userName = hmm & user.userPassword = 111
                                      fullSubName = name + '.' + subName;
                                      // fullSubName =  subName;
                                      innerObj = {};
                                      innerObj[fullSubName] = subValue;
                                      query += param(innerObj) + '&';
                                  }
                              }
                          }
                          else if(value !== undefined ) //&& value !== null
                          {
                              console.log("undefined");
                              query += encodeURIComponent(name) + '=' + encodeURIComponent(value) + '&';
                          }
                      }


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


                  return angular.isObject(data) && String(data) !== '[object File]' ? param(data) : data;
              }]


              $httpProvider.defaults.useXDomain = true;
              // delete $httpProvider.defaults.headers.common['X-Requested-With'];
          }])

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值