我有一个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);
}
答案 0 :(得分:1)
您可以转换字符串并使用分隔符,然后在服务器端解析它。您也可以使用 HttpPost 代替 HttpGet 请求,这样您就可以发送JSON字符串,并且更容易解析。
答案 1 :(得分:1)
根据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);
}