gpt4 book ai didi

java - 使用 AngularJS 传递参数时 Resteasy @FormParam null

转载 作者:搜寻专家 更新时间:2023-11-01 02:43:57 27 4
gpt4 key购买 nike

我正在尝试在前端使用 AngularJS,并将 Resteasy 用作 Rest API。我的问题是,在使用 AngularsJS 发送参数时,我的@FormParam 始终为 null。

我的 JS 是这样的:

$scope.addPerson = function(newFirstName, newLastName) {
$http({
method: 'POST',
url: "rest/persons/savePerson",
data: {firstName: 'newFirstName', lastName: 'newLastName'},
headers: {'Content-Type': 'application/json'}
})
.success(function(data) {
alert("DATA : " + data);
}).error(function(data, status, headers, config) {
alert("Could not save new person");
});
};

这是我的代码服务器端:

@POST
@Path("/savePerson")
@Produces("application/json")
@Secured({ "ROLE_USER" })
public PersonBean savePerson(@FormParam("firstName") String firstName,
@FormParam("lastName") String lastName) {
if (firstName== null || lastName== null) {
return null;
}
PersonBean person = personDao.savePerson(firstName,
lastName);
return person ;
}

感谢任何帮助。

最佳答案

您将字段作为 JSON 而不是表单编码数据发布。

headers: {'Content-Type': 'application/json'}

但是你不能只改变这个标题。这些值将需要进行形式编码。请参阅此页面,了解如何从 Angular 发布表单数据。

http://www.bennadel.com/blog/2615-posting-form-data-with-http-in-angularjs.htm

不过,您可能会发现坚持使用 JSON 并让您的框架为您将这些字段映射到一个 Bean 会更好。

我没有使用过 Resteasy,但我认为它应该像...一样简单

@POST
@Path("/savePerson")
@Consumes("application/json")
@Produces("application/json")
@Secured({ "ROLE_USER" })
public PersonBean savePerson(SavePersonBean savePersonBean) {
PersonBean person = personDao.savePerson(savePersonBean.getFirstName(),
savePersonBean.getLastName());
return person;
}

关于java - 使用 AngularJS 传递参数时 Resteasy @FormParam null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26877246/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com