springboot2.x 整合redis 多数据源 以及注解实现表单校验

注入redis

import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.annotation.PropertyAccessor; import com.fasterxml.jackson.databind.ObjectMapper; import org.springframework.beans.factory.annotation.Value; import org.springframework.cache.CacheManager; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.connection.RedisPassword; import org.springframework.data.redis.connection.RedisStandaloneConfiguration; import org.springframework.data.redis.connection.jedis.JedisClientConfiguration; import org.springframework.data.redis.connection.jedis.JedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.RedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer; import redis.clients.jedis.JedisPoolConfig;

import java.time.Duration;

/** */ @Configuration public class RedisNoRepeatSubmitConfiguration { @Value("${spring.redisNoRepeatSubmit.host:192.168.0.219}") private String redisHost;

@Value("${spring.redisNoRepeatSubmit.port:6379}")
private int redisPort;

@Value("${spring.redisNoRepeatSubmit.timeout:20000}")
private int redisTimeout;

@Value("${spring.redisNoRepeatSubmit.password:sunvua1028}")
private String redisAuth;

@Value("${spring.redisNoRepeatSubmit.database:0}")
private int redisDb;
@Value("${spring.redisNoRepeatSubmit.pool.max-active:20}")
private int maxActive;

@Value("${spring.redisNoRepeatSubmit.pool.max-wait:-1}")
private int maxWait;

@Value("${spring.redisNoRepeatSubmit.pool.max-idle:8}")
private int maxIdle;

@Value("${spring.redisNoRepeatSubmit.pool.min-idle:0}")
private int minIdle;
@Bean(name="NoRepeatSubmit")
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, Object> template = new RedisTemplate<>();
    // 配置连接工厂
    JedisPoolConfig poolConfig = new JedisPoolConfig();
    poolConfig.setMaxTotal(maxActive);
    poolConfig.setMaxIdle(maxIdle);
    poolConfig.setMaxWaitMillis(maxWait);
    poolConfig.setMinIdle(minIdle);
    poolConfig.setTestOnBorrow(true);
    poolConfig.setTestOnReturn(false);
    poolConfig.setTestWhileIdle(true);
    JedisClientConfiguration clientConfig = JedisClientConfiguration.builder()
            .usePooling().poolConfig(poolConfig).and().readTimeout(Duration.ofMillis(redisTimeout)).build();
    // 单点redis
    RedisStandaloneConfiguration redisConfig = new RedisStandaloneConfiguration();
    // 哨兵redis
    // RedisSentinelConfiguration redisConfig = new RedisSentinelConfiguration();
    // 集群redis
    // RedisClusterConfiguration redisConfig = new RedisClusterConfiguration();
    redisConfig.setHostName(redisHost);
    redisConfig.setPassword(RedisPassword.of(redisAuth));
    redisConfig.setPort(redisPort);
    redisConfig.setDatabase(redisDb);
    factory=new JedisConnectionFactory(redisConfig,clientConfig);
    template.setConnectionFactory(factory);
    //使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值(默认使用JDK的序列化方式)
    Jackson2JsonRedisSerializer jacksonSeial = new Jackson2JsonRedisSerializer(Object.class);
    ObjectMapper om = new ObjectMapper();
    // 指定要序列化的域,field,get和set,以及修饰符范围,ANY是都有包括private和public
    om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
    // 指定序列化输入的类型,类必须是非final修饰的,final修饰的类,比如String,Integer等会跑出异常
    om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
    jacksonSeial.setObjectMapper(om);
    // 值采用json序列化
    template.setValueSerializer(jacksonSeial);
    //使用StringRedisSerializer来序列化和反序列化redis的key值
    template.setKeySerializer(new StringRedisSerializer());
    // 设置hash key 和value序列化模式
    template.setHashKeySerializer(new StringRedisSerializer());
    template.setHashValueSerializer(jacksonSeial);
    template.afterPropertiesSet();
    //开启事务 与 @Transactional(rollbackFor = Exception.class) 一起使用
    template.setEnableTransactionSupport(true);
    return template;
}

} //创建 注解 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;

/**

  • 防止表单重复提交 按钮 */ @Target(ElementType.METHOD) // 作用到方法上 @Retention(RetentionPolicy.RUNTIME) // 运行时有效 public @interface NoRepeatSubmit { String value() default "3";//3秒内不可重复提交 }

创建表单验证aop import com.sunvua.coeus.core.columnaccess.annotation.NoRepeatSubmit; import com.sunvua.coeus.core.constant.SysConstants; import com.sunvua.coeus.core.json.JsonResult; import com.sunvua.coeus.ext.common.util.HttpUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.ValueOperations; import org.springframework.stereotype.Component;

import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import java.util.concurrent.TimeUnit;

/**

  • @Author jsc

  • 防止表达提交aop **/ @Aspect @Component public class NoRepeatSubmitAop { private Log logger = LogFactory.getLog(getClass()); @Resource(name="NoRepeatSubmit") private RedisTemplate<String, Object> redisTemplate; @Autowired protected HttpServletRequest request; @Around(value = "@annotation(nrs)") public Object arround(ProceedingJoinPoint pjp, NoRepeatSubmit nrs) { ValueOperations<String, Object> opsForValue = redisTemplate.opsForValue(); try { String userId = HttpUtils.getRequestUserId(); if(userId==null||userId.equals(SysConstants.USER_ANONYMOUS)){ logger.error("没有登录权限"); return JsonResult.fail("没有登录权限"); } String key ="NoRepeatSubmit:"+ userId + "&" + request.getServletPath(); if (opsForValue.get(key) == null) {// 如果缓存中有这个url视为重复提交 // Object o = pjp.proceed(); opsForValue.set(key, key, Long.valueOf(nrs.value()), TimeUnit.SECONDS); Object result = pjp.proceed(); //执行方法 return result; } else { logger.error("重复提交"); return JsonResult.fail("重复提交"); } } catch (Throwable e) { logger.error("重复提交{}",e); return JsonResult.fail("没有登录权限"); }

    }

}

测试方法 @RequestMapping("/test") @NoRepeatSubmit 3秒不可提交 public String test(){ return "success" ; }

@RequestMapping("/test2") @NoRepeatSubmit("100") 100秒不可重复提交 public JsonResult test2(){ return JsonResult.success("success") ; }

转载于:https://my.oschina.net/u/3022323/blog/3098364

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值