使用 Angular 的 $http 通过 GET 请求将对象数组发送到 Java Spring

IT小君   2022-09-15T08:28:53

我有一个 javascript 变量,它是 MyObjects 的数组。我可以使用以下代码将此变量显示到视图中:

        <tr ng-repeat="user in lala.users">
            <td>{{ user.firstName }}</td>
            <td>{{ user.lastName }}</td>
        </tr>

现在我正在尝试将此数组发送到服务器。我正在尝试类似的东西:

    lala.send = function() {
        $http({
            method: 'GET',
            url: "http://localhost:8080/server/" + lala.users
        }).then(function successCallback(response) {
            if (response.status == 200) {
                lala.users = response.data
            }
        });
    };

如何将此数组传递给服务器端的列表?直到现在我有这样的东西。

@RequestMapping(value = "/server/{users}", method = RequestMethod.GET, produces = MediaType.APPLICATION_JSON_VALUE)
    public ResponseEntity<List<MyObjects>> transform(@PathVariable("users") String[] users) {
        List<MyObjects> results2 = new ArrayList<>();

        //pass array to a list??

        return new ResponseEntity<>(results2, HttpStatus.OK);
    }
点击广告,支持我们为你提供更好的服务
评论(2)
IT小君

您可以转换字符串并使用分隔符,然后在服务器端解析它。您还可以使用HttpPost代替HttpGet请求,这样您就可以发送 JSON 字符串并且更容易解析。

2022-09-15T08:28:53   回复
IT小君

根据 Ranielle 的回答,我继续使用 HttpPost。

这是代码:

lala.send = function() {
            $http.post("http://localhost:8080/server", lala.users ) 
            .then(function successCallback(response) {
                if (response.status == 200) {
                   lala.users = response.data
                }
            });
        };

还有春天的一面

@RequestMapping(value = "server", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
    public ResponseEntity<List<MyObjects> sort( @RequestBody List<MyObjects> query) {
        List<MyObjects> results2 = new ArrayList<>();

        for(MyObjects a : query) {
                System.out.println(a.getFirstName());
        }

        return new ResponseEntity<>(results2, HttpStatus.OK);
    }
2022-09-15T08:28:53   回复