在Spring Boot应用程序中将数据存储到数据库时出现问题

时间:2018-06-26 06:54:02

标签: json spring-boot spring-data-jpa hibernate-mapping spring-data-rest

在Spring Boot应用程序中使用发布请求将数据保存到数据库时出现错误。 我在类之间有多对多映射。从数据库中获取数据时,我没有任何问题,但是当我尝试将数据保存到数据库时,出现此错误。

2018-06-26 12:19:32.016  WARN 3156 --- [nio-8080-exec-1] .c.j.MappingJackson2HttpMessageConverter : Failed to evaluate Jackson deserialization for type [[simple type, class com.greydelta.entity.Permission]]: com.fasterxml.jackson.databind.exc.InvalidDefinitionException: Cannot handle managed/back reference 'defaultReference': back reference type (java.util.List) not compatible with managed type (com.greydelta.entity.Role)
2018-06-26 12:19:32.018  WARN 3156 --- [nio-8080-exec-1] .c.j.MappingJackson2HttpMessageConverter : Failed to evaluate Jackson deserialization for type [[simple type, class com.greydelta.entity.Permission]]: com.fasterxml.jackson.databind.exc.InvalidDefinitionException: Cannot handle managed/back reference 'defaultReference': back reference type (java.util.List) not compatible with managed type (com.greydelta.entity.Role)

我在父实体和子实体类中使用@JsonManagedReference@JsonBackReference

这是我的映射 Child类:

    // test this mapping
@ManyToMany(mappedBy="permissions",
        cascade={ CascadeType.DETACH, CascadeType.MERGE, CascadeType.PERSIST, CascadeType.REFRESH })
@JsonBackReference
private List<Role> roles;

Parent类:

    // test this mapping
@ManyToMany(fetch = FetchType.EAGER,
        cascade = {CascadeType.PERSIST, CascadeType.MERGE, CascadeType.DETACH, CascadeType.REFRESH})
@JoinTable( name="role_permission",
            joinColumns= {@JoinColumn(name="role_id")},
            inverseJoinColumns= {@JoinColumn(name="permission_id")})
@JsonManagedReference
private List<Permission> permissions; // create getter/setter

更新:

这是用户发送POST请求以创建角色的URL:                     本地主机:8080 /角色

这是我在邮递员中得到的答复:

{
    "timestamp": "2018-06-26T08:18:03.167+0000",
    "status": 415,
    "error": "Unsupported Media Type",
    "message": "Content type 'application/json;charset=UTF-8' not supported",
    "path": "/roles"
}

这是控制器方法:

@PostMapping("/roles")
public void createRole(@RequestBody Role theRole) {     

    roleService.createRole(theRole);

}

1 个答案:

答案 0 :(得分:1)

我通过删除@JsonManagedReference解决了这个问题。 如果您有两个以上的实体映射在一起,则需要在每个实体类中删除@JsonManagedReference。我在这里找到了这个解决方案:

Spring REST, JSON "Can not handle managed/back reference 'defaultReference'" 415 Unsupported Media Type

我希望这会有所帮助。