Table des matières
一、配置Spring-session-redis 的关键配置如下:
二、查看 RedisHttpSessionConfiguration 源代码如下:
三、RedisTemplate 初始化代码如下:
Maison base de données Redis Quelle est la méthode de sérialisation par défaut pour modifier Springsession Redis ?

Quelle est la méthode de sérialisation par défaut pour modifier Springsession Redis ?

Jun 02, 2023 pm 03:58 PM
redis springsession

一、配置Spring-session-redis 的关键配置如下:

    <!-- 设置Cookie domain 和 名称 -->
    <bean id="defaultCookieSerializer" class="org.springframework.session.web.http.DefaultCookieSerializer">
        <property name="domainName" value="${sso.cookie.domain}"/>
        <property name="cookieName" value="${sso.cookie.name}"/>
        <property name="cookieMaxAge" value="${sso.cookie.maxage}" />
        <property name="cookiePath" value="${sso.cookie.path}" />
        <!--<property name="domainNamePattern" value="^.+?\\.(\\w+\\.[a-z]+)$"/>-->
    </bean>

	<!-- 配置spring session -->
	<bean class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
		<!-- session超时设置 -->
		<property name="maxInactiveIntervalInSeconds" value="${spring.session.expiration}" />
        <property name="cookieSerializer" ref="defaultCookieSerializer" />
	</bean>

二、查看 RedisHttpSessionConfiguration 源代码如下:

	@Bean
	public RedisTemplate<Object, Object> sessionRedisTemplate(
			RedisConnectionFactory connectionFactory) {
		RedisTemplate<Object, Object> template = new RedisTemplate<Object, Object>();
		template.setKeySerializer(new StringRedisSerializer());
		template.setHashKeySerializer(new StringRedisSerializer());
		if (this.defaultRedisSerializer != null) {
			template.setDefaultSerializer(this.defaultRedisSerializer);
		}
		template.setConnectionFactory(connectionFactory);
		return template;
	}

	@Bean
	public RedisOperationsSessionRepository sessionRepository(
			@Qualifier("sessionRedisTemplate") RedisOperations<Object, Object> sessionRedisTemplate,
			ApplicationEventPublisher applicationEventPublisher) {
		RedisOperationsSessionRepository sessionRepository = new RedisOperationsSessionRepository(
				sessionRedisTemplate);
		sessionRepository.setApplicationEventPublisher(applicationEventPublisher);
		sessionRepository
				.setDefaultMaxInactiveInterval(this.maxInactiveIntervalInSeconds);
		if (this.defaultRedisSerializer != null) {
			sessionRepository.setDefaultSerializer(this.defaultRedisSerializer);
		}

		String redisNamespace = getRedisNamespace();
		if (StringUtils.hasText(redisNamespace)) {
			sessionRepository.setRedisKeyNamespace(redisNamespace);
		}

		sessionRepository.setRedisFlushMode(this.redisFlushMode);
		return sessionRepository;
	}

创建RedisTemplate时,指定的默认序列化是:StringRedisSerializer,当 defaultRedisSerializer != null 时,重新指定了序列化方法。以下是 defaultRedisSerializer 的初始化代码:

	@Autowired(required = false)
	@Qualifier("springSessionDefaultRedisSerializer")
	public void setDefaultRedisSerializer(
			RedisSerializer<Object> defaultRedisSerializer) {
		this.defaultRedisSerializer = defaultRedisSerializer;
	}

因此,我们只需要创建名为 springSessionDefaultRedisSerializer 的Bean,及可修改默认序列化方法。

<bean id="springSessionDefaultRedisSerializer" class="org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer" />

注:使用JSON序列化,在特定的场景,会报错,谨慎使用。

三、RedisTemplate 初始化代码如下:

	public void afterPropertiesSet() {

		super.afterPropertiesSet();

		boolean defaultUsed = false;

		if (defaultSerializer == null) {

			defaultSerializer = new JdkSerializationRedisSerializer(
					classLoader != null ? classLoader : this.getClass().getClassLoader());
		}

		if (enableDefaultSerializer) {

			if (keySerializer == null) {
				keySerializer = defaultSerializer;
				defaultUsed = true;
			}
			if (valueSerializer == null) {
				valueSerializer = defaultSerializer;
				defaultUsed = true;
			}
			if (hashKeySerializer == null) {
				hashKeySerializer = defaultSerializer;
				defaultUsed = true;
			}
			if (hashValueSerializer == null) {
				hashValueSerializer = defaultSerializer;
				defaultUsed = true;
			}
		}

		if (enableDefaultSerializer && defaultUsed) {
			Assert.notNull(defaultSerializer, "default serializer null and not all serializers initialized");
		}

		if (scriptExecutor == null) {
			this.scriptExecutor = new DefaultScriptExecutor<K>(this);
		}

		initialized = true;
	}

从句式和语序上调整,可将原话重写为:"如果未指定默认值,使用JdkSerializationRedisSerializer。"。

特别提醒:如果已有session中存在旧有的序列化值,更换序列化方法后,要删除旧值,使用新的序列化进行调试,否则会报序列化错误。

特别提醒:如果已有session中存在旧有的序列化值,更换序列化方法后,要删除旧值,使用新的序列化进行调试,否则会报序列化错误。

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!

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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1545
276
Comment limiter les ressources des utilisateurs dans Linux? Comment configurer Ulimit? Comment limiter les ressources des utilisateurs dans Linux? Comment configurer Ulimit? May 29, 2025 pm 11:09 PM

Linux System restreint les ressources utilisateur via la commande UliMIT pour éviter une utilisation excessive des ressources. 1.Ulimit est une commande shell intégrée qui peut limiter le nombre de descripteurs de fichiers (-n), la taille de la mémoire (-v), le nombre de threads (-u), etc., qui sont divisés en limite douce (valeur effective actuelle) et limite dure (limite supérieure maximale). 2. Utilisez directement la commande ulimit pour une modification temporaire, telle que Ulimit-N2048, mais elle n'est valable que pour la session en cours. 3. Pour un effet permanent, vous devez modifier /etc/security/limits.conf et les fichiers de configuration PAM, et ajouter SessionRequiredPam_limits.so. 4. Le service SystemD doit définir Lim dans le fichier unitaire

Laravel Page Cache Policy Laravel Page Cache Policy May 29, 2025 pm 09:15 PM

La stratégie de mise en cache de la page de Laravel peut améliorer considérablement les performances du site Web. 1) Utilisez des fonctions de cache d'assistance pour implémenter la mise en cache de page, telles que la méthode Cache :: Rappelez-vous. 2) Sélectionnez le backend de cache approprié, tel que redis. 3) Faites attention aux problèmes de cohérence des données et vous pouvez utiliser des caches à grain fin ou des auditeurs d'événements pour effacer le cache. 4) Une optimisation supplémentaire est combinée avec le cache de routage, les étiquettes de cache et de cache d'afficher. En appliquant rationnellement ces stratégies, les performances du site Web peuvent être effectivement améliorées.

Redis Master-Slave Replication Failure Dépannage du processus de dépannage Redis Master-Slave Replication Failure Dépannage du processus de dépannage Jun 04, 2025 pm 08:51 PM

Les étapes de dépannage et de réparation des défaillances de réplication des esclaves de Redis incluent: 1. Vérifiez la connexion réseau et utilisez Ping ou Telnet pour tester la connectivité; 2. Vérifiez le fichier de configuration Redis pour vous assurer que la réplique et le temps de remplacement sont définis correctement; 3. Vérifiez le fichier journal Redis et recherchez des informations d'erreur; 4. S'il s'agit d'un problème de réseau, essayez de redémarrer le périphérique réseau ou de changer le chemin alternatif; 5. S'il s'agit d'un problème de configuration, modifiez le fichier de configuration; 6. S'il s'agit d'un problème de synchronisation des données, utilisez la commande SlaveOf pour réintégrer les données.

Qu'est-ce que Redis et en quoi diffère-t-il des bases de données SQL traditionnelles? Qu'est-ce que Redis et en quoi diffère-t-il des bases de données SQL traditionnelles? May 24, 2025 am 12:13 AM

RedisisuniqueComperedTotraditionalsqldatabasesInSeverAlways: 1) itoperatesprimy inmemory, permettant à la base de laadandwriteoperations.2)

Emplacement rapide et manipulation des échecs de nœud de cluster redis Emplacement rapide et manipulation des échecs de nœud de cluster redis Jun 04, 2025 pm 08:54 PM

Les étapes d'emplacement et de traitement rapides de la défaillance du nœud de cluster redis sont les suivantes: 1. Confirmez le défaut: utilisez la commande CluSterodes pour afficher l'état du nœud. Si l'échec est affiché, le nœud échouera. 2. Déterminez la cause: vérifiez le réseau, le matériel et la configuration. Les problèmes courants incluent les limites de mémoire dépassant. 3. Réparation et restauration: prenez des mesures basées sur les raisons, telles que le redémarrage du service, le remplacement du matériel ou la modification de la configuration. 4. Remarques: Assurer la cohérence des données, sélectionner les politiques de basculement appropriées et établir des systèmes de surveillance et d'alarme.

Méthodes et stratégies pour résoudre le problème du cerveau fendu dans le cluster redis Méthodes et stratégies pour résoudre le problème du cerveau fendu dans le cluster redis Jun 04, 2025 pm 08:42 PM

Des solutions efficaces au problème du cerveau divisé dans le cluster redis comprennent: 1) l'optimisation de la configuration du réseau pour assurer la stabilité de la connexion; 2) Surveillance du nœud et détection des défauts, surveillance en temps réel avec outils; 3) Mécanisme de basculement, fixant des seuils élevés pour éviter plusieurs nœuds maître; 4) Garantie de cohérence des données, en utilisant la fonction de réplication pour synchroniser les données; 5) Intervention et récupération manuelle et traitement manuel si nécessaire.

Comparaison des performances et scénarios d'application conjointe entre Redis et Rabbitmq Comparaison des performances et scénarios d'application conjointe entre Redis et Rabbitmq Jun 04, 2025 pm 08:45 PM

Redis et RabbitMQ ont chacun leurs propres avantages dans les scénarios de performance et d'application conjointe. 1.Redis fonctionne parfaitement dans la lecture et l'écriture des données, avec une latence de hausses pour les microsecondes, adapté à des scénarios de concurrence élevés. 2.Rabbitmq se concentre sur la messagerie, la latence en millisecondes et prend en charge les modèles multi-quelles et consommateurs. 3. Dans les applications conjointes, Redis peut être utilisé pour le stockage des données, RabbitMQ gère les tâches asynchrones et améliore la vitesse et la fiabilité de la réponse du système.

Suggestions de configuration pour améliorer les performances de persistance redis Suggestions de configuration pour améliorer les performances de persistance redis Jun 04, 2025 pm 08:48 PM

Les méthodes pour améliorer les performances de persistance redis via la configuration incluent: 1. Ajustez les paramètres de sauvegarde de RDB pour réduire la fréquence de génération d'instantané; 2. Définissez le paramètre APPENDFSYNC d'AOF sur EverySEC; 3. Utilisez AOF et RDB en combinaison; 4. Utilisez des paramètres sans apprendfsync-on-liwrite pour optimiser les performances de réécriture AOF; 5. Activer le mode de persistance hybride. Ces configurations peuvent améliorer les performances tout en garantissant la sécurité des données.

See all articles