当我向实体发布更新时,我一直在寻找解决我在spring-boot / spring-mvc项目中获得的以下异常消息的解决方案:
o.s.w.s.m.m.a.HttpEntityMethodProcessor : Written [{timestamp=Wed Jan 14 11:15:34 MST 2015, status=400, error=Bad Request, exception=org.springframework.http.converter.HttpMessageNotReadableException, message=Could not read JSON: Can not deserialize instance of java.util.HashSet out of START_OBJECT token
at [Source: org.apache.catalina.connector.CoyoteInputStream@7f5840c4; line: 1, column: 146] (through reference chain: com.company.product.model.people.dto.EmployeeDTO["user"]->com.company.product.security.dto.UserDTO["roles"]); nested exception is com.fasterxml.jackson.databind.JsonMappingException: Can not deserialize instance of java.util.HashSet out of START_OBJECT token
然而,看起来我的情况与我在StackOverflow和Jackson文档中看到的其他情况略有不同。
以下是我的两个数据结构:
public class EmployeeDTO {
List<WorkdayDTO> workDays = new ArrayList<WorkdayDTO>();
private UserDTO user;
...
public List<WorkdayDTO> getWorkDays() {
return workDays;
}
public void setWorkDays(List<WorkdayDTO> workDays) {
this.workDays = workDays;
}
public UserDTO getUser() {
return user;
}
public void setUser(UserDTO user) {
this.user = user;
}
}
和
public class UserDTO {
private boolean credentialsNonExpired;
private OfficeDTO office;
@JsonProperty("roles") // <-- added this based on early research, hasn't helped though
private Set<String> roles = new HashSet<String>();
// .. standard getters & setters
}
当我做GET时,我的json响应是:
[
{
"employeeId":1,
"endDateTime":null,
"workDays":[
],
"ssn":"111-22-3333",
"maskedSsn":null,
"user":{
"username":"user@test.com",
"password":null,
"enabled":true,
"accountNonExpired":true,
"accountNonLocked":true,
"credentialsNonExpired":true,
"office":null,
"roles":[
"OWNER"
]
},
"address":{
...
}
},
{
"employeeId":2,
"endDateTime":null,
"workDays":[
...
],
"ssn":"333-44-5555",
"maskedSsn":null,
"user":{
"username":"userA@test.com",
"password":null,
"enabled":true,
"accountNonExpired":true,
"accountNonLocked":true,
"credentialsNonExpired":true,
"office":null,
"roles":[
"MANAGER"
]
},
"address":{
...
}
}
]
似乎它不喜欢我的employee.user.roles列表中的单个字符串,但添加“@JsonProperty(”roles“)”也没有帮助。
答案 0 :(得分:5)
POST的正文格式不正确。它包含roles
的JSON对象。 JSON对象无法映射到HashSet
,因此失败。您的JSON中的roles
需要是一个数组。