Spring 用我自己的自定义反序列化程序替换OAuth2AccessTokenJackson2Deserializer

Spring 用我自己的自定义反序列化程序替换OAuth2AccessTokenJackson2Deserializer,spring,spring-boot,Spring,Spring Boot,这个类正在反序列化一个oauth2令牌,我想对它进行调整。我创建了自己的类,扩展了StdDeserializer,目前它与原始类相同 下面是课堂: public class MyCustomDeserializer extends StdDeserializer<OAuth2AccessToken> { public MyCustomDeserializer() { super(OAuth2AccessToken.class); } @Override public OA

这个类正在反序列化一个oauth2令牌,我想对它进行调整。我创建了自己的类,扩展了StdDeserializer,目前它与原始类相同

下面是课堂:

public class MyCustomDeserializer extends StdDeserializer<OAuth2AccessToken> {

public MyCustomDeserializer() {
    super(OAuth2AccessToken.class);
}

@Override
public OAuth2AccessToken deserialize(JsonParser jp, DeserializationContext ctxt) throws IOException,
        JsonProcessingException {

    String tokenValue = null;
    String tokenType = null;
    String refreshToken = null;
    Long expiresIn = null;
    Set<String> scope = null;
    Map<String, Object> additionalInformation = new LinkedHashMap<String, Object>();

    // TODO What should occur if a parameter exists twice
    while (jp.nextToken() != JsonToken.END_OBJECT) {
        String name = jp.getCurrentName();
        jp.nextToken();
        if (OAuth2AccessToken.ACCESS_TOKEN.equals(name)) {
            tokenValue = jp.getText();
        }
        else if (OAuth2AccessToken.TOKEN_TYPE.equals(name)) {
            tokenType = jp.getText();
        }
        else if (OAuth2AccessToken.REFRESH_TOKEN.equals(name)) {
            refreshToken = jp.getText();
        }
        else if (OAuth2AccessToken.EXPIRES_IN.equals(name)) {
            try {
                expiresIn = jp.getLongValue();
            } catch (JsonParseException e) {
                expiresIn = Long.valueOf(jp.getText());
            }
        }
        else if (OAuth2AccessToken.SCOPE.equals(name)) {
            scope = parseScope(jp);
        } else {
            additionalInformation.put(name, jp.readValueAs(Object.class));
        }
    }

    // TODO What should occur if a required parameter (tokenValue or tokenType) is missing?

    DefaultOAuth2AccessToken accessToken = new DefaultOAuth2AccessToken(tokenValue);
    accessToken.setTokenType(tokenType);
    if (expiresIn != null) {
        accessToken.setExpiration(new Date(System.currentTimeMillis() + (expiresIn * 1000)));
    }
    if (refreshToken != null) {
        accessToken.setRefreshToken(new DefaultOAuth2RefreshToken(refreshToken));
    }
    accessToken.setScope(scope);
    accessToken.setAdditionalInformation(additionalInformation);

    return accessToken;
}

private Set<String> parseScope(JsonParser jp) throws JsonParseException, IOException {
    Set<String> scope;
    if (jp.getCurrentToken() == JsonToken.START_ARRAY) {
        scope = new TreeSet<String>();
        while (jp.nextToken() != JsonToken.END_ARRAY) {
            scope.add(jp.getValueAsString());
        }
    } else {
        String text = jp.getText();
        scope = OAuth2Utils.parseParameterList(text);
    }
    return scope;
}
在测试上述代码时,流没有到达我的类,而是到达原始类。我使用的是spring boot 2.1.4

@Bean
public ObjectMapper configObjectMapper() {
    final ObjectMapper objectMapper = new ObjectMapper();
    objectMapper.enable(SerializationFeature.INDENT_OUTPUT);
    final SimpleModule module = new SimpleModule("configModule",   com.fasterxml.jackson.core.Version.unknownVersion());
    module.addDeserializer(OAuth2AccessToken.class, new MyCustomDeserializer());
    objectMapper.registerModule(module);
    return objectMapper;
}