前两天在搞自己的项目,前端js框架用的是angularjs框架;网站整的差不多的时候出事了;那就是当我用$http.post()方法向服务器提交一些数据的时候;后台总是接收不到数据;
于是采用了其他方法暂时性替代一下;
今天正好有时间研究这个事情;网上查了很多资料;都试了试;都是不太好;但是还是给我提供了一些解决问题的思路;
正文开始:首先做了个demo如下;主要是为了比较他们的不同之处;
html如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
< div class="container-fluid" data-ng-app="jjd" data-ng-controller="index">
< div class="container">
< div class="row">
< div class="col-md-5">
< p class="h4 text-center">jQ的$.post()提交</ p >
< p > </ p >
< div class="form-group">
< label for="exampleInputEmail1">用户名</ label >
< input type="text" ng-model="sdata.name" class="form-control" placeholder="用户名">
</ div >
< div class="form-group">
< label for="">密码</ label >
< input type="password" ng-model="sdata.pwd" class="form-control" placeholder="密码">
</ div >
< button type="button" class="btn btn-primary btn-block" ng-click="jPostData()">jQ提交</ button >
</ div >
< div class="col-md-2"> </ div >
< div class="col-md-5">
< p class="h4 text-center">angularjs的$http.post()功能</ p >
< p > </ p >
< div class="form-group">
< label for="exampleInputEmail1">用户名</ label >
< input type="text" ng-model="sdata2.name" class="form-control" placeholder="用户名">
</ div >
< div class="form-group">
< label for="">密码</ label >
< input type="password" ng-model="sdata2.pwd" class="form-control" placeholder="密码">
</ div >
< button type="button" class="btn btn-primary btn-block" ng-click="aPostData()">$http提交</ button >
</ div >
</ div >
</ div >
</ div >
|
js代码如下:
var app = angular.module('jjd',[]);
app.controller('index',function($scope,$http){
$scope.sdata = {
name:'jQuery',
pwd:'jQuery'
};
$scope.sdata2 = {
name:'Angularjs',
pwd:'Angularjs'
};
/*jQ的ajax提交*/
$scope.jPostData = function(){
//console.log($scope.sdata);
$.post('/web/data.php',$scope.sdata,function(d){
console.log(d);
})
};
/*angularjs的$http提交*/
$scope.aPostData = function(){
$http({
url: '/web/data.php',
method: 'POST',
data:$scope.sdata2
}
}).success(function(da){
console.log(da);
});
};
});
后台采用php的$_POST接收:
<?php
header("Content-type: text/html; charset=utf-8");
$aname = $_POST['name'];
$apwd = $_POST['pwd'];
$msg = array();
$msg['name'] = $aname;
$msg['pwd'] = $apwd;
echo json_encode($msg);
?>
服务器采用wampsever的本地启动的本地服务器。致此,页面服务搭建完毕;开始测试;
结果如图:
从上图的对比中可以看出后台接收不到值得原因主要是1、2、3处不同;
其中1和2是请求的头文件信息;
3是数据类型不同;jq发送的是Form Data;而angularjs默认发送的是json数据;
产生原因已经找到;下面开始改造;
首先针对1和2,在$http()的方法中配置header信息;
其次对数据进行转换;这里我做了个简单的json到string转换的服务;
改造后的代码如下:
/*------创建angularjs应用------*/
var app = angular.module('jjd',[]);
/*创建json格式到string的转换服务*/
app.service('jsonToStr',function(){
this.transform = function(jsonData){
var string = '';
for(str in jsonData){
string = string + str +'=' + jsonData[str] +'&';
}
var _last = string.lastIndexOf('&');
string = string.substring(0,_last);
return string;
};
});
/*---------首页控制器--------*/
app.controller('index',function($scope,$http,jsonToStr){//注入创建的jsonToStr服务
$scope.sdata = {
name:'jQuery',
pwd:'jQuery'
};
$scope.sdata2 = {
name:'Angularjs',
pwd:'Angularjs'
};
/*jQ的ajax提交*/
$scope.jPostData = function(){
//console.log($scope.sdata);
$.post('/web/data.php',$scope.sdata,function(d){
console.log(d);
})
};
/*angularjs的$http提交*/
$scope.aPostData = function(){
//console.log(jsonToStr.transform($scope.sdata2));
$http({
url: '/web/data.php',
method: 'POST',
data:$scope.sdata2,
data: jsonToStr.transform($scope.sdata2),//对提交的数据格式化
headers: {
'Accept': '*/*',
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
}
}).success(function(da){
console.log(da);
});
};
});
致此,angularjs提交数据后台接收不到的问题解决(只针对json数据格式);献给奋斗中的小伙伴;