主頁 > 知識庫 > redis 解決key的亂碼問題,并清理詳解

redis 解決key的亂碼問題,并清理詳解

熱門標簽:四川穩(wěn)定外呼系統(tǒng)軟件 400電話辦理的口碑 廊坊外呼系統(tǒng)在哪買 地圖標注工廠入駐 南京手機外呼系統(tǒng)廠家 b2b外呼系統(tǒng) 一個地圖標注多少錢 高碑店市地圖標注app 臺灣電銷

key亂碼問題

因redis默認使用JdkSerializationRedisSerializer來進行序列化,造成key是亂碼,如下:

keys '*!report:flag:phon*'

1) "\xac\xed\x00\x05t\x00!report:flag:phone_156464"

2) "\xac\xed\x00\x05t\x00!report:flag:phone_198946"

3) "\xac\xed\x00\x05t\x00!report:flag:phone_183302"

解決key亂碼

private RedisTemplate redisTemplate;

 @Autowired(required = false)
 public void setRedisTemplate(RedisTemplate redisTemplate) {
  RedisSerializer stringSerializer = new StringRedisSerializer();
  redisTemplate.setKeySerializer(stringSerializer);
  redisTemplate.setValueSerializer(stringSerializer);
  redisTemplate.setHashKeySerializer(stringSerializer);
  redisTemplate.setHashValueSerializer(stringSerializer);
  this.redisTemplate = redisTemplate;
 }

清理亂碼key

官方不支持 del '*keys'方式模糊/批量刪除key。但是keys命令支持模糊匹配,所以采取以下方式:

方式1:可刪除正常key,無法刪除亂碼key

redis-cli -h 192.168.1.21 -a password -n 2 --scan --pattern '*!report:flag:phon*' | xargs redis-cli -h 192.168.1.21 -a password -n 2 DEL

方式2:成功刪除

del "\xac\xed\x00\x05t\x00!report:flag:phone_183302" "\xac\xed\x00\x05t\x00!report:flag:phone_198946"

補充知識:redis key和value的亂碼問題解決,含日期轉(zhuǎn)化格式問題

在項目中,遇到的問題是redis的key和value出現(xiàn)的亂碼問題:在這里插入圖片描述

而原本的內(nèi)容為下:

{
  "status":"success",
  "data":{
    "id":3,
    "title":"花林",
    "price":99,
    "stock":81,
    "description":"美女一只",
    "sales":17,
    "imgUrl":"https://xiaolei1996.oss-cn-shanghai.aliyuncs.com/blog/title/we1.jpg",
    "promoStatus":2,
    "promoPrice":50,
    "promoId":1,
    "startDate":"2020-03-23 21:50:59"
  }
}

原因: 是因為和redis內(nèi)部的編碼協(xié)議出現(xiàn)了問題,所以需要改進。spring提供了一個優(yōu)化方案。springboot的redisTemplate改進。

@Component
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600)
public class RedisConfig {
  @Bean
  public RedisTemplate redisTemplate(RedisConnectionFactory factory){
    RedisTemplate redisTemplate = new RedisTemplate();
    redisTemplate.setConnectionFactory(factory);

    //首先解決key的序列化問題
    StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
    redisTemplate.setKeySerializer(stringRedisSerializer);

    //解決value的序列化問題
    Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
    redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);

    return redisTemplate;
  }
}

比之前好了,但是還有點小問題,json的數(shù)據(jù)比以前多了,這是因為日期的轉(zhuǎn)化出現(xiàn)問題,這塊的知識觸及盲區(qū),就先把解決方案寫下面,以后有時間在研究。

public class JodaDateTimeJsonSerializer extends JsonSerializerDateTime> {
  @Override
  public void serialize(DateTime value, JsonGenerator gen, SerializerProvider serializers) throws IOException {
    gen.writeString(value.toString("yyyy-MM-dd HH:mm:ss"));

  }
}
public class JodaDateTimeJsonDeserializer extends JsonDeserializerDateTime> {
  @Override
  public DateTime deserialize(JsonParser p, DeserializationContext ctxt
  ) throws IOException, JsonProcessingException {
    String dateString= p.readValueAs(String.class);
    DateTimeFormatter dateTimeFormatter = DateTimeFormat.forPattern("yyyy-MM-dd HH:mm:ss");

    return DateTime.parse(dateString,dateTimeFormatter);//轉(zhuǎn)成
  }
}
@Component
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600)
public class RedisConfig {
  @Bean
  public RedisTemplate redisTemplate(RedisConnectionFactory factory){
    RedisTemplate redisTemplate = new RedisTemplate();
    redisTemplate.setConnectionFactory(factory);

    //首先解決key的序列化問題
    StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
    redisTemplate.setKeySerializer(stringRedisSerializer);

    //解決value的序列化問題
    Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
    redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);

    //改進日期轉(zhuǎn)化問題
    ObjectMapper objectMapper = new ObjectMapper();
    SimpleModule simpleModule = new SimpleModule();
    simpleModule.addSerializer(DateTime.class,new JodaDateTimeJsonSerializer());
    simpleModule.addDeserializer(DateTime.class,new JodaDateTimeJsonDeserializer());

//解決反序列化問題	objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
    objectMapper.registerModule(simpleModule);
    jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
    redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);

    return redisTemplate;
  }
}

最后終于出現(xiàn)了預(yù)期的效果

以上這篇redis 解決key的亂碼問題,并清理詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • redis中的數(shù)據(jù)結(jié)構(gòu)和編碼詳解
  • window手動操作清理redis緩存的技巧總結(jié)
  • redis中key的設(shè)置方法步驟

標簽:畢節(jié) 河源 伊春 定州 拉薩 南寧 甘南 泰州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《redis 解決key的亂碼問題,并清理詳解》,本文關(guān)鍵詞  redis,解決,key,的,亂碼,問題,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《redis 解決key的亂碼問題,并清理詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于redis 解決key的亂碼問題,并清理詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章