Maison > base de données > Redis > le corps du texte

Comment résoudre le problème des objets tronqués stockés dans Redis intégré à Springboot

王林
Libérer: 2023-05-28 09:25:05
avant
1712 Les gens l'ont consulté

springboot a intégré le code tronqué de l'objet de stockage Redis

En fait, ce n'est pas une sorte de code tronqué en substance, c'est juste quelque chose qui est stocké après la sérialisation. Lorsque nous utilisons RedisTemplete pour stocker des objets, si. l'objet n'a pas été sérialisé signalera une erreur. Ce que vous obtenez après la sérialisation ne correspond pas aux données souhaitées. Afin de résoudre cette méthode, nous pouvons utiliser StringRedisTemplete

Parlons du code#🎜🎜. #

Lors de l'utilisation de redistemplete par défaut

/**
 * title: list
 *
 *  当我们保存到redis中的是一个对象时,我们会发现会报错,提示我们需要序列化 ,
 *  当我们继承了序列化接口之后,查看设置的值时,我们发现设置的值不是原来的样字,
 *  此时我们可以通过两种方式解决
 *      1.
 *
 * @author : ZHeng
 */
@SpringBootTest
public class RedisListTest01 {

//    @Autowired
//    StringRedisTemplate stringRedisTemplate;

    @Autowired
    RedisTemplate redisTemplate;

    @Test
    public void test(){
        redisTemplate.opsForValue().set("user1",new User(2,"lisi",19));
        System.out.println(redisTemplate.opsForValue().get("user1"));
    }
}
Copier après la connexion

Lorsque nous l'exécuterons, nous trouverons une erreur ! Indiquez-nous que l'objet User n'est pas sérialisé.

org.springframework.data.redis.serializer.SerializationException : impossible de sérialiser ; l'exception imbriquée est org.springframework.core.serializer.support.SerializationFailedException : échec de la sérialisation de l'objet à l'aide de DefaultSerializer ; l'exception est java.lang.IllegalArgumentException : DefaultSerializer nécessite une charge utile sérialisable mais a reçu un objet de type [com.xxx.redis01.model.User]

 …..

Causé par : java. lang.IllegalArgumentException : DefaultSerializer nécessite une charge utile sérialisable mais a reçu un objet de type [com.xxx.redis01.model.User]
sur org.springframework.core.serializer.DefaultSerializer.serialize(DefaultSerializer.java:43 )# 🎜🎜# sur org.springframework.core.serializer.Serializer.serializeToByteArray(Serializer.java:56)
sur org.springframework.core.serializer.support.SerializingConverter.convert(SerializingConverter.java:60)# 🎜🎜 # … 72 de plus


Processus terminé avec le code de sortie -1


Exécuter après avoir sérialisé l'objet Utilisateur#🎜 🎜#

public class User implements Serializable {
    private Integer id;
    private String name;
    private Integer age;
    //省略getter setter toString等
}
Copier après la connexion
#🎜🎜 #Oh mon dieu, ce n'est plus tronqué !!!, mais quand tu utilises Linux pour te connecter à distance et vérifier les clés, tu trouveras, hein ? C'est tronqué ici. . .

2022-04-01 20:32:07.666 INFO 18640 --- [ main] com.xxx.redis01.RedisListTest01 : Aucun profil actif défini, retour à 1 profil par défaut : "default"

2022-04-01 20:32:07.998 INFO 18640 --- [ main] .s.d.r.c.RepositoryConfigurationDelegate : plusieurs modules Spring Data trouvés, entrant en mode de configuration de référentiel strict !

2022-04-01 20:32:08.000 INFO 18640 --- [ main] .s.d.r.c.RepositoryConfigurationDelegate : Amorçage des référentiels Spring Data Redis en mode PAR DÉFAUT.

2022-04-01 20:32:08.018 INFO 18640 --- [ Principal] .s.d.r.c. RepositoryConfigurationDelegate : analyse du référentiel Spring Data terminée en 5 ms. 0 interfaces de référentiel Redis trouvées. en 1,488 secondes (JVM fonctionnant sous 2,517)
User{id=2, name='lisi', age='19'}


Processus terminé avec le code de sortie 0
# 🎜 🎜#
Qu'est-ce que c'est que ça ? C'est évidemment user1. Qu'est-ce que c'est ?

127.0.0.1:6379> keys *
¬쳵ser1
Copier après la connexion

Vous pouvez envisager d'utiliser StringRedisTemplete

Il n'y a certainement pas qu'une seule solution, il suffit de l'étudier et de l'enregistrer vous-même, pour référence seulement#🎜 🎜#

@SpringBootTest
public class RedisListTest01 {

    @Autowired
    StringRedisTemplate stringRedisTemplate;

    @Test
    public void test(){
        stringRedisTemplate.opsForValue().set("user1",new User(2,"lisi",19).toString());
        System.out.println(stringRedisTemplate.opsForValue().get("user1"));
    }
}
Copier après la connexion

L'obtenir avec succès
User{id=2, name='lisi', age='19'}
Copier après la connexion

Jetons un coup d'oeil sous Linux, c'est ok aussi

127.0.0.1:6379> keys *
user1
127.0.0.1:6379> get user1
User{id=2, name='lisi', age='19'}
127.0.0.1:6379>
Copier après la connexion

Bien sûr il existe une autre façon de l'enregistrer au format JSON , ce qui n'est pas couvert ici Mettez le code

Résoudre le problème tronqué de Redis

Ajoutez simplement une classe de configuration directement

/**解决redis中文乱码
 * Created by dgx on 2019/8
 */
@Configuration
public class Config {

    @Autowired
    private RedisTemplate redisTemplate;

    @Bean
    public RedisTemplate redisTemplateInit() {
        //设置序列化Key的实例化对象
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        //设置序列化Value的实例化对象
        redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        return redisTemplate;
    }
}
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:yisu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal