2

WebSessionを Redisに保存したいと考えています。put 操作では問題ありませんが、格納されたレコードを取得するときに例外がスローされます。これが私のスタックトレースの例です

temporal.ChronoUnit","SECONDS"],["java.time.temporal.ChronoUnit","NANOS"]]]"[切り捨てられた 18 バイト]; 行: 1、列: 1]

どうすればこの問題を解決できますか? なぜそれが起こっているのか理解できませんか?ありがとう。

これが私のセッションサービスです。

@Component
@RequiredArgsConstructor
@Slf4j
public class SessionMappingStorage {

    private static final String USR_TO_SESSION___KEY = "USR_SESSION_MAP";

    private final ReactiveHashOperations<String, String, Object> hashOps;

    public Mono<Boolean> addSession(String username, WebSession session) {
       return hashOps.put(USR_TO_SESSION___KEY, username, session);
    }

    public Mono<WebSession> getSessionByUserId(String username) {
       return hashOps.get(USR_TO_SESSION___KEY, username).cast(WebSession.class);  
    }
}

これが私のredis構成です。

@Bean
public ReactiveRedisTemplate<String, String> reactiveRedisTemplate() {
    RedisSerializer keySerializer, hashKeySerializer, hashValueSerializer;
    keySerializer = hashKeySerializer = new StringRedisSerializer();
    hashValueSerializer = new GenericJackson2JsonRedisSerializer(objectMapper());

    RedisSerializationContext.RedisSerializationContextBuilder<String, String> builder =
            RedisSerializationContext.newSerializationContext(keySerializer);
    RedisSerializationContext<String, String> context =
            builder.hashKey(hashKeySerializer).hashValue(hashValueSerializer).build();

    return new ReactiveRedisTemplate<>(reactiveRedisConnectionFactory(), context);
}

@Bean
public ReactiveHashOperations<String, String, Object> hashOps() {
    return reactiveRedisTemplate().opsForHash();
}

private ObjectMapper objectMapper() {
    ObjectMapper mapper = new ObjectMapper();
    mapper.enableDefaultTyping();
    return mapper;
}
4

0 に答える 0