package com.xcong.excoin.common.aop; import cn.hutool.core.util.StrUtil; import cn.hutool.crypto.asymmetric.KeyType; import cn.hutool.crypto.asymmetric.RSA; import com.xcong.excoin.common.LoginUserUtils; import com.xcong.excoin.common.annotations.SubmitRepeat; import com.xcong.excoin.common.contants.AppContants; import com.xcong.excoin.common.response.Result; import com.xcong.excoin.configurations.properties.SecurityProperties; import com.xcong.excoin.utils.MessageSourceUtils; import com.xcong.excoin.utils.RedisUtils; import lombok.extern.slf4j.Slf4j; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.*; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.web.context.request.RequestContextHolder; import org.springframework.web.context.request.ServletRequestAttributes; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; /** * @author wzy * @date 2020-04-16 22:01 **/ @Slf4j @Aspect @Component public class SubmitRepeatAspect { @Resource private RedisUtils redisUtil; @Resource private SecurityProperties securityProperties; private String key; @Pointcut("@annotation(submitRepeat)") public void submitRepeatPointCut(SubmitRepeat submitRepeat) { } @Before("submitRepeatPointCut(submitRepeat)") public void before(SubmitRepeat submitRepeat) { } @Around("submitRepeatPointCut(submitRepeat)") public Object around(ProceedingJoinPoint joinPoint, SubmitRepeat submitRepeat) throws Throwable { ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = attributes.getRequest(); //String token = request.getHeader("token"); String bearerToken = request.getHeader(AppContants.TOKEN_HEADER); String rsaToken = bearerToken.replace(AppContants.TOKEN_START_WITH, ""); RSA rsa = new RSA(securityProperties.getPrivateKey(), null); String[] tokens = StrUtil.split(rsa.decryptStr(rsaToken, KeyType.PrivateKey), "_"); String token = tokens[0]; String uri = request.getRequestURI(); Long mId = LoginUserUtils.getAppLoginUser().getId(); //String mId = (String) redisUtil.get(token); //log.info("#token : {}, uri : {}, mId : {}#", token, uri, mId); key = mId + "_" + uri; boolean flag = redisUtil.setNotExist(key, "1", 5); //log.info("#mid : {}, flag : {}#", mId, flag); if (flag) { Object result = joinPoint.proceed(); redisUtil.del(key); return result; } else { return Result.fail(MessageSourceUtils.getString("submit_repeat")); } } @After("submitRepeatPointCut(submitRepeat)") public void after(SubmitRepeat submitRepeat) { } @AfterThrowing(throwing = "ex", pointcut = "submitRepeatPointCut(submitRepeat)") public void afterThrows(JoinPoint jp, Exception ex, SubmitRepeat submitRepeat) throws Exception { log.error("#submit repeat error:#", ex); redisUtil.del(key); throw new Exception("系统繁忙"); } }