2

我需要将实体对象转换为 json。我放

<bean class = "org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
    <property name="messageConverters">
        <array>
            <bean class = "org.springframework.http.converter.StringHttpMessageConverter">
                <property name="supportedMediaTypes" value = "text/plain;charset=UTF-8" />
            </bean>
            <bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
                <property name="supportedMediaTypes" value="application/json" />
                <property name="objectMapper">
                    <ref bean="JacksonObjectMapper" />
                </property>
            </bean>
        </array>
    </property>
</bean>

<bean id="JacksonObjectMapper" class="org.codehaus.jackson.map.ObjectMapper" />

到 servlet 配置文件,因此 Spring 可以自动将对象转换为 json 格式。但是 Spring 并没有这样做。我还将杰克逊罐子添加到项目中。

控制器方法

@RequestMapping(value = "/addData.html", method = RequestMethod.POST)
public @ResponseBody GroupStudent addNewGroup(@RequestBody GroupStudent group) {
    return group;    
}

小组学生

@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;

}

在浏览器中我发现我有 406 错误和错误窗口错误 [object Object]。

如果有人知道问题是什么,我将不胜感激。

谢谢你。

4

2 回答 2

1

如果您的对象加入了其他表,那么您只能通过以下方式执行此操作。

首先,让我们用@JsonManagedReference、@JsonBackReference 来注释关系,让Jackson 更好地处理关系:

这是“用户”实体:

public class User {
    public int id;
    public String name;

    @JsonBackReference
    public List<Item> userItems;
}

和“项目”:

public class Item {
    public int id;
    public String itemName;

    @JsonManagedReference
    public User owner;
}

现在让我们测试一下新实体:

@Test
public void
  givenBidirectionRelation_whenUsingJacksonReferenceAnnotation_thenCorrect()
  throws JsonProcessingException {

    User user = new User(1, "John");
    Item item = new Item(2, "book", user);
    user.addItem(item);

    String result = new ObjectMapper().writeValueAsString(item);

    assertThat(result, containsString("book"));
    assertThat(result, containsString("John"));
    assertThat(result, not(containsString("userItems")));
}

这是序列化的输出:

{
 "id":2,
 "itemName":"book",
 "owner":
    {
        "id":1,
        "name":"John"
    }
}

注意:

@JsonManagedReference 是引用的前向部分——正常序列化的部分。@JsonBackReference 是引用的后面部分——它将从序列化中省略。

引用自以下链接。您可以访问更多。

杰克逊——双向关系

于 2017-08-15T15:05:06.967 回答
0

@RequestMapping(produces="application/json")是您需要的,不要忘记在您的 JS 代码中发出 POST 请求(而不是 GET)。

于 2013-11-12T18:19:22.927 回答