在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);
}
答案 0 :(得分:1)
我通过删除@JsonManagedReference解决了这个问题。 如果您有两个以上的实体映射在一起,则需要在每个实体类中删除@JsonManagedReference。我在这里找到了这个解决方案:
我希望这会有所帮助。