Java AngularJS$http vs$http.post

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

我对AngularJS是新手,正在尝试

我想将数据发送到服务器并将其映射到REST服务之一中的DTO。 所以我是这样做的

         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被发送回嵌套了一层太深的服务?您是否找到了原因?