使用redis的hash数据结构存放登录用户的信息
注意:这个纯粹是为了方便了我日后复习的,很多东西都省略了
1 springboot项目中导入redis的依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2 配置redis的序列化器,就是让存入redis中的数据不是乱码的
package com.zpark.forum.config;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.cache.RedisCacheWriter;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.StringRedisSerializer;
@Configuration
public class RedisConfig2 {
@Bean
@SuppressWarnings("all")
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory){
RedisTemplate<Object, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
//jason格式
//主要配置了jackson2JsonRedisSerializer 和stringRedisSerializer两个序列化器
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper om = new ObjectMapper();
om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(om);
StringRedisSerializer stringRedisSerializer=new StringRedisSerializer();
template.setKeySerializer(stringRedisSerializer);
template.setValueSerializer(jackson2JsonRedisSerializer);
template.setHashKeySerializer(stringRedisSerializer);
template.setHashValueSerializer(jackson2JsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
//这个是使用@EnableCaching等注解做缓存的时候解决存入redis的数据的乱码问题 (项目暂时用不到,可以不配先)
@Bean
public RedisCacheManager redisCacheManager(RedisTemplate redisTemplate) {
RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisTemplate.getConnectionFactory());
RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(redisTemplate.getValueSerializer()));
return new RedisCacheManager(redisCacheWriter, redisCacheConfiguration);
}
}
3 把登录用户存进redis中
@Override
public Result login(User user) {
if(StringUtils.isEmpty(user.getNickname()) ||
StringUtils.isEmpty(user.getUserType()) ||
StringUtils.isEmpty(user.getPassword())){
return Result.ok(300,Constant.lackMsg);
}
List<User> loginuser=userMapper.login(user);
if(loginuser!=null && loginuser.size()>0){
//将登录用户的信息存入redis
redisTemplate.opsForHash().put("user","login-user",loginuser);
redisTemplate.expire("user",10, TimeUnit.SECONDS);
Map<Object, Object> map = new HashMap<>();
map.put("result",loginuser);
return Result.ok(Constant.okCode,Constant.loginSuccess,map);
}
return Result.fail(Constant.failCode,Constant.loginFail);
}
主要是者几句:存入redis并设置过期时间
redisTemplate.opsForHash().put("user","login-user",loginuser);
redisTemplate.expire("user",10, TimeUnit.SECONDS);