使用PagedResources / embedded对象反序列化日期。杰克逊。弹簧

时间:2017-11-07 06:42:50

标签: java json spring jackson objectmapper

我定义了@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()这是我的自定义方法,但问题并非如此。 那么如何才能得到正确的结果,正确的反序列化?

我的其他课程:SomeDtoResponseSomeEntity

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

1 个答案:

答案 0 :(得分:0)

确保您使用的Date类应该是以下类型:

import java.util.Date;

如果是Java.sql.Date,则会导致您遇到的问题。 我希望这能解决你的问题。