我有实体类GroupStudent,Spring Controller和带有ajax函数的JSP页面。在Controller中,我尝试使用@ResponseBody将实体GroupStudent对象传递给JSP页面。但我总是从浏览器中得到错误:错误[object Object]。我发现我需要在项目jackson-core-asl和jackson-mapper-asl jar中添加到lib文件夹。我添加了它们(版本1.9.7)并将其放到spring-servlet.xml中,以便它可以自动将GroupStudent对象转换为json格式并将其传递回ajax函数。但它没有帮助,我总是在浏览器中有相同的错误对话框。如果有人知道如何使用@ResponseBody将实体对象传递给ajax,我将非常感谢您的帮助。
谢谢。
GroupStudent类
@Entity
@Table(name = "GroupStudent")
@NamedQueries({
@NamedQuery(name = "GroupStudent.getAllGroups", // get all groups
query = "select g from GroupStudent g"),
@NamedQuery(name = "GroupStudent.getGroupByName", // get group by name
query = "select g from GroupStudent g where g.groupStudentNumber = :name")
})
public class GroupStudent implements Serializable {
public GroupStudent() {}
public GroupStudent(String groupStudentNumber) {
this.groupStudentNumber = groupStudentNumber;
}
// create connectivity with table Student
private Set<Student> students = new HashSet<Student>();
@OneToMany(mappedBy = "groupStudent", cascade = CascadeType.ALL, orphanRemoval = true)
public Set<Student> getStudents() {
return this.students;
}
public void setStudents(Set<Student> students) {
this.students = students;
}
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "group_id_seq")
@SequenceGenerator(name = "group_id_seq", sequenceName = "GroupStudent_seq", allocationSize = 1)
@Column(name = "GroupStudentId")
public Long getGroupStudentId() {
return this.groupStudentId;
}
public void setGroupStudentId(Long groupStudentId) {
this.groupStudentId = groupStudentId;
}
@Column(name = "GroupStudentNumber")
public String getGroupStudentNumber() {
return this.groupStudentNumber;
}
public void setGroupStudentNumber(String groupStudentNumber) {
this.groupStudentNumber = groupStudentNumber;
}
// table GroupStudent fields
private Long groupStudentId;
private String groupStudentNumber;
}
控制器
@RequestMapping(value = "/addData.html", method = RequestMethod.POST)
public @ResponseBody GroupStudent addNewGroup(@RequestBody GroupStudent group) {
return group;
}
}
Ajax功能
function addGroupAjax() {
var groupStudentNumber = $('#groupStudentNumber').val();
$.ajax({
type: "POST",
url: "/IRSystem/addData.html",
contentType: "application/json; charset=utf-8",
dataType: "json",
mimeType: "application/json",
data: "{\"groupStudentNumber\":" + "\"" + groupStudentNumber + "\"}",
success: function(response) {
},
error: function(e) {
alert("Error" + e);
}
});
}
答案 0 :(得分:0)
您可以尝试将produces="application/json"
添加到@RequestMapping
,使其看起来像@RequestMapping(value = "/addData.html", method = RequestMethod.POST, produces="application/json")
。
另外,我没有看到它,你错过了POST方法的@ResponseBody
注释。在这篇博文http://www.javacodegeeks.com/2013/07/spring-mvc-requestbody-and-responsebody-demystified.html中,您可以看到它的作用。简短回答:它可以帮助您进行序列化/反序列化,并将序列化对象直接写入响应流,因此您不必手动执行。
此外,检查您的登录服务器以查看是否有任何错误,如果没有(如果您使用的是Chrome),请打开设置 - &gt;工具 - &gt;开发人员工具 - &gt;联网,再次拨打你的电话。从显示您的呼叫的列表中选择元素,然后您可以确切地看到服务器返回的内容。