Java AngularJS$http vs$http.post
我对AngularJS是新手,正在尝试 我想将数据发送到服务器并将其映射到REST服务之一中的DTO。 所以我是这样做的Java AngularJS$http vs$http.post,java,jquery,angularjs,angularjs-directive,Java,Jquery,Angularjs,Angularjs Directive,我对AngularJS是新手,正在尝试 我想将数据发送到服务器并将其映射到REST服务之一中的DTO。 所以我是这样做的 saveUserUrl = "http://localhost:8080/App/rest/UserManager/saveUser"; var results = []; for (var i = $scope.users.length; i--;) { var user = $scope.u
saveUserUrl = "http://localhost:8080/App/rest/UserManager/saveUser";
var results = [];
for (var i = $scope.users.length; i--;) {
var user = $scope.users[i];
results.push(user);
}
$http.post(saveUserUrl, {
data: results,
headers: {'Content-Type': undefined,'Authorization':$routeParams.auth },
transformRequest: function(data, headersGetterFunction) {
return data;
}
}).
success(function(data, status, headers, config) {
if(status == 203) {
alert("Session Timed out, Please Login Again");
$window.location=getContextFromURL();
}else{
alert("user saved success");
}
}).
error(function(data, status, headers, config) {
alert("user saved failure");
});
有效载荷
{"data":
[{"id":2,"name":"Agent3","extn":3,"group":1,"groupName":"Agent","isNew":false},
{"id":1,"name":"Agent2","extn":"2","group":1,"groupName":"Agent","isNew":false}
],
"headers":
{"Authorization":"5825ccb2-d28b-47e6-87a8-0b31f8ec9a78"}
}
休息服务
@POST
@Path("/saveUser")
@Produces({ MediaType.APPLICATION_JSON} )
@Consumes({ MediaType.APPLICATION_JSON} )
public Response saveUser(@HeaderParam(HttpHeaders.AUTHORIZATION) String authorization,@Context HttpServletRequest req, DBUserEntity dbUser ) {
System.out.println("User iiss :" + dbUser);
ResponseBuilder responseBuilder = Response.status(200);
//System.out.println("zipStatus :"+zipStatus);
//TODO
return responseBuilder.entity(null).build();
}
一切正常
现在我尝试用这种方法作为所有服务器调用的通用函数,但它停止了工作
$http({
url: urlBase+requestMapping,
method: method,
data: formData,
headers: {
'Content-Type': contentType,
'Authorization':$routeParams.auth
},
transformRequest: function(data, headersGetterFunction) {
return data; // do nothing! FormData is very good!
}
});
它停止工作了。
有效载荷如下所示:
[object Object],[object Object]
我尝试了JSON.stringify,然后它作为
[
{
"id": 2,
"name": "Agent23",
"extn": 23,
"group": 1,
"groupName": "Agent",
"isNew": false,
"$$hashKey": "object:11"
},
{
"id": 1,
"name": "Agent22",
"extn": "22",
"group": 1,
"groupName": "Agent",
"isNew": false,
"$$hashKey": "object:10"
}
]
我不知道$http和$http.post的正确工作方式,在每种发送数据的方式中,是否有任何特定的事情需要注意。
$http.post
只是$http
与方法:'post'
的快捷方式。
在您的示例中,运行
$http({
url: saveUserUrl,
method: 'POST',
data: results,
headers: {'Content-Type': undefined,'Authorization':$routeParams.auth },
transformRequest: function(data, headersGetterFunction) {
return data;
}
});
应该产生与原始
$http.post
请求完全相同的结果,因为它没有发送相同的负载,或者我做错了什么,我也发布了负载,它没有发送。您确定URL正确吗?您是否收到服务器的任何响应?相同的URL适用于这两种情况,第一种情况下有效,第二种情况下无效,因为负载不同,无法映射到正确的REST服务方法。@yarons我遇到了相同的问题。问题是,为什么在使用$http.post而不是$http with method:post时,JSON被发送回嵌套了一层太深的服务?您是否找到了原因?