Получение NullPointer вместо создания токена - PullRequest
0 голосов
/ 14 февраля 2019

В настоящее время я пишу приложение Spring Boot с использованием JWT.При тестировании функциональности, отвечающей за создание токена с использованием разных дат, я столкнулся с проблемой.Ну, вместо токена я получаю NullPointer.Вот как я это проверяю:

@Test
public void testGenerateTokenFromDifferentDates() {
    when(clockMock.now())
            .thenReturn(DateUtil.yesterday())
            .thenReturn(DateUtil.now());

    String token = createToken();
    String tokenLater = createToken();

    assertThat(token).isNotEqualTo(tokenLater);
}

private String createToken() {
    String token = tokenUtil.generateToken(new TestUser(USERNAME));
    return token;
}

И этот класс отвечает за создание токена:

@Component
public class TokenUtil implements Serializable {
    private static final long serialVersionUID = -3301605591108950415L;
    @Value("${jwt.secret}")
    private String secret;
    private Clock clock = DefaultClock.INSTANCE;
    @Value("${jwt.expires.days}")
    private Long expiration;

    public String getUsernameFromToken(String token) {
        return getClaimsFromToken(token, Claims::getSubject);
    }

    public <T> T getClaimsFromToken(String token, Function<Claims, T> resolverClaims) {
        final Claims claims = getAllClaimsFromToken(token);
        return resolverClaims.apply(claims);
    }

    public String generateToken(UserDetails userDetails) {
        Map<String, Object> claims = new HashMap<>();
        return doGenerateToken(claims, userDetails.getUsername());
    }

    private Claims getAllClaimsFromToken(String token) {
        return Jwts.parser().setSigningKey(secret).parseClaimsJwt(token).getBody();
    }

    private String doGenerateToken(Map<String, Object> claims, String subject) {
        final Date createdDate = clock.now();
        final Date expirationDate = calculateExpirationDate(createdDate);

        return Jwts.builder()
            .setClaims(claims)
            .setSubject(subject)
            .setIssuedAt(createdDate)
            .setExpiration(expirationDate)
            .signWith(SignatureAlgorithm.HS512, this.secret)
            .compact();
    }

    private Date calculateExpirationDate(Date createdDate) {
        return new Date(createdDate.getTime() + expiration * 1000);
    }
}

Я не могу понять, в чем причина.Отладчик также не помогает мне, потому что это не доходит до этого момента.Вот репозиторий .Как предложил @theonlyrao, трассировка стека:

java.lang.NullPointerException
at com.github.springjwt.security.jwt.TokenUtil.calculateExpirationDate(TokenUtil.java:59)
at com.github.springjwt.security.jwt.TokenUtil.doGenerateToken(TokenUtil.java:47)
at com.github.springjwt.security.jwt.TokenUtil.generateToken(TokenUtil.java:38)
at com.github.springjwt.security.jwt.TokenUtilTest.createToken(TokenUtilTest.java:42)
at com.github.springjwt.security.jwt.TokenUtilTest.testGenerateTokenFromDifferentDates(TokenUtilTest.java:35)

1 Ответ

0 голосов
/ 15 февраля 2019

Кажется, что createdDate или expiration равны нулю.

Я не уверен, как создать экземпляр createdDate, потому что я не использовал эту библиотеку DefaultClock.

Я думаю, что проблема с expiration в том, что вы не сказали Spring, где искать свойства приложения в вашем тесте.Если это не происходит в другом месте кода, вам необходимо указать путь к ресурсу, как описано в https://www.baeldung.com/spring-classpath-file-access.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...