【发布时间】:2018-09-23 12:50:36
【问题描述】:
对于我正在进行的项目,我需要使用库 io.jsonwebtoken (jjwt) 提供的 Spring Security 和 JSON Webtokens。我需要添加到生成的令牌中的声明之一是以下实体(简化以说明问题):
@Entity
public class MyEntity {
private String name;
private LocalDateTime ldt;
}
这可行,但生成的 webtoken 序列化如下:
{
"sub": "testuser@mydomain.com",
"exp": 1523659655,
"entity": {
"name": testname,
"ldt": {
"hour": 0,
"minute": 37,
"dayOfMonth": 12,
"dayOfWeek": "THURSDAY",
"dayOfYear": 102,
"year": 2018,
"month": "APRIL",
"monthValue": 4,
"second": 38,
"nano": 569000000,
"chronology": {
"calendarType": "iso8601",
"id": "ISO"
}
}
}
}
这看起来可能不是问题,但实际上当我需要再次将它映射到 MyEntity 的实例时,它实际上是一个问题。在线阅读后,我想我需要更改 ObjectMapper 的配置,以更改配置选项(将WRITE_DATES_AS_TIMESTAMPS-flag 切换为 false)。但是,我无法更改 jjwt 使用的 ObjectMapper 的配置,因为它是这样构造的(jjwt 的来源):
public class DefaultJwtBuilder implements JwtBuilder {
private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper();
...
}
我在网上找到的另一个选择是将以下行放在我的 application.properties 文件中:
spring.jackson.serialization.WRITE_DATES_AS_TIMESTAMPS = false
然而无济于事,jjwt使用的ObjectMapper似乎忽略了这些属性。
我会做些什么来实现我的目标?
【问题讨论】:
标签: java spring jackson2 jsr310 jjwt