当AngularJS POST方法碰上PHP

问题描述

怎么POST过去给PHP都收不到资料?

$_POST方法取不到正确的传入值!

原理说明

AngularJS这套framework使用的AJAX方法中,资料传递的格式为JSON,送出去的header

Content-Type: application/json

而非JQuery 或是HTML form 送出的

multipart/form-data

application/x-www-form-urlencoded

解决办法

  1. AngularJS 配合,去把请求的header 改成PHP 能够接受的
  2. PHP 配合,改成接受JSON 格式的请求

我个人比较倾向解决办法2(以JSON沟通为主),JSON格式在前后端的沟通上有着很好的弹性,前端包装,??后端收到资料轻松的拆解。

先说办法1 的解法,首先要把预设值改掉

//替换成自己的模组名称后使用config设定header
angular.module("YourAppModule", ["SomeModule"]).config(function($httpProvider) {
  $httpProvider.defaults.headers.put[‘Content-Type‘] =
    ‘application/x-www-form-urlencoded‘;
  $httpProvider.defaults.headers.post[‘Content-Type‘] =
    ‘application/x-www-form-urlencoded‘;
});

如上解法

但是这样只会让POST方法中,传资料的栏位,变成一次送出1团,而且是无属性栏位只有的一团!(就是JSON字串)

所以要

用AngularJS 的方法自己写一个中间层(interceptor)来打包请求/回应

$httpProvider.interceptors.push([‘$q‘, function($q) {
  return {
    request: function(config) {
      if (config.data && typeof config.data === ‘object‘) {
          //请求在这边做处理,下方针对请求的资料打包
        config.data = serialize(config.data);
        //serialize 序列化的程式码可以参考下方
      }
        return config || $q.when(config);
    }
  };
}]);

ref: 参考 <<推荐一读

var serialize = function(obj, prefix) {
    var str = [];
    for(var p in obj) {
        var k = prefix ? prefix + "[" + p + "]" : p, v = obj[p];
        str.push(typeof v == "object" ? serialize(v, k) : encodeURIComponent(k) + "=" + encodeURIComponent(v));
      }
    return str.join("&");
}

ref: 参考

如此一来,PHP 在后端的部分可以完全不用修改,就接上啰!

虽然有点多此一举,但是从这可以知道,AngularJS 有interceptor 可以来包装请求/回应这件事的设计其实还满不错的说~

针对无登入或任何伺服器回应事件,前端网页需要做跳转还是其他处理时有个中控管理的机制,减少在其他方法的判断与code 的维护

接下来是办法2

不改动到前端,对后端PHP做一点修改

$content_type_args = explode(‘;‘, $_SERVER[‘CONTENT_TYPE‘]);
if ($content_type_args[0] == ‘application/json‘)
  $_POST = json_decode(file_get_contents(‘php://input‘),true);

ref: 参考

在使用$_POST方法前或档案开头处,补上这三行就OK,与以往开发无两样!

原理就是把前端传过来的JSON 做parsing 配给$_POST ,搞定

此文转载!

时间: 2024-12-10 23:06:40

当AngularJS POST方法碰上PHP的相关文章

avaScript文件中调用AngularJS内部方法或改变$scope变量

需要在其他JavaScript文件中调用AngularJS内部方法或改变$scope变量,同时还要保持双向数据绑定: 首先获取AngularJS application: 方法一:通过controller来获取app var appElement = document.querySelector('[ng-controller=mainController]'); 然后在获取$scope变量: var $scope = angular.element(appElement).scope(); 如

AngularJS 工具方法以及AngularJS中使用jQuery

1. AngularJS 工具方法,参考angularjs API https://docs.angularjs.org/api官方文档 (1)angular.isArray(value) 判断是否是数组,返回true/false [html] view plain copy <div ng-controller="firstController">{{isArray}}</div> [html] view plain copy $scope.arr=[1,2,

AngularJS工具方法

1 2 3 4 var myApp = angular.module('myApp', []);//ng-app模块化,[]内为依赖的其他模块 myApp.controller('Aaa', ['$scope', function ($scope) {     $scope.name = 'hello'; }]); 1 2 3 4 5 6 7 8 function show(n1, n2) {     alert(n1);     alert(n2);     alert(this); } an

AngularJS - Apply方法监听model变化

<body> <div ng-app="myApp"> <div ng-controller="firstController" ng-click="show();"> {{name}} {{age}} </div> </div> <script type="text/javascript"> var app = angular.module("

angularjs 初始化方法执行两次以及url定义错误导致传值错误问题

1.初始化方法执行两次以上的问题定义一个 route.如下所示:.state('main.channelQryDetail', { url:'/channelDetail/:channelNo/:pageFlag', templateUrl:'views/channel/channelDetail.html', controller: 'channelDetailCtr', ncyBreadcrumb: { label: '渠道详细', parent: 'main.channelQuery' }

angularjs——工具方法

1.fromJson 把json字符串转成JSON对象 var jsonStr='[{"Name":"abc","age":12},{"Name":"ffff","age":22}]'; var objJson=angular.fromJson(jsonStr); console.log(objJson); 2.toJson 把JSON对象转成JSON字符串. 注意:第一个参数要转换的对

angularjs 工具方法

<!DOCTYPE HTML> <html ng-app> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>无标题文档</title> <script src="angular.min.js"></script> <script&g

angularjs控制器方法

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title></title> <link rel="stylesheet" href=""> &l

Angularjs js方法参数动态传入

$scope.pageNumberCount = 10; <li  ng-repeat="i in pageNumberCount">     <a ng-click="clickPagination(i)">{{i}}</a> <!--注意:这里的参数不能写成"{{i}}"--> </li>