我定义了@Bean
objectMapper
并设置了这样的日期格式:
ObjectMapper mapper = new ObjectMapper();
mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm"));
当方法返回正常ResponseEntity<SomeDTO>
时,它会起作用。
示例JSON响应:
{
"id": 888,
"createdDate": "2017-11-06 13:50",
}
但是当我的控制器方法返回ResponseEntity<PagedResources<SomeDTOResponse>>
时,createdDate
没有被反序列化,我得到了:
{
"_embedded": {
"someEntityResponseList": [
{
"id": 877,
"createdDate": 1509877100151
}
]
},
"_links": {
...
},
"page": {
...
}
}
我的控制器:
@RequestMapping(method = RequestMethod.GET)
public ResponseEntity<PagedResources<SomeDTOResponse>> getAllActiveAuctionsForLoggedUser(
Pageable pageable, PagedResourcesAssembler assembler) {
Page<SomeEntity> someEntites = someEntityService.getAllSomeEntities(pageable);
Page<SomeDTOResponse> response = assembler.toResource(someEntites.map(entity -> mapToResponse(entity))
return new ResponseEntity<>(response, HttpStatus.OK);
}
当我在最后一行return...
中放置断点时,对象response
包含:createdDate = {Timestamp@12184} "2017-11-05 10:54:14.345"
。 mapToResponse()
这是我的自定义方法,但问题并非如此。
那么如何才能得到正确的结果,正确的反序列化?
我的其他课程:SomeDtoResponse
和SomeEntity
。
@Data
public class SomeDtoResponse {
private Long id;
private Date createdDate;
}
@Entity
@Table(name = "SOME_ENTITY")
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
public class SomeEntity {
@Id
@GeneratedValue
@Column(name = "SOME_ENTITY_ID")
private Long id;
@NotNull
private Date createdDate;
}
答案 0 :(得分:0)
确保您使用的Date类应该是以下类型:
import java.util.Date;
如果是Java.sql.Date,则会导致您遇到的问题。 我希望这能解决你的问题。