From 81da61b828e29b7745e1382dfbbaeb685dc083ef Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期二, 23 一月 2024 17:17:55 +0800 Subject: [PATCH] 抖音转链修改 --- fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java | 227 ++++++++++++++++++++++++++++---------------------------- 1 files changed, 114 insertions(+), 113 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java b/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java index 1ad960c..e436eb1 100644 --- a/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java +++ b/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java @@ -1,113 +1,114 @@ -package com.yeshi.fanli.aspect; - -import java.lang.reflect.Method; - -import javax.annotation.Resource; - -import org.aspectj.lang.JoinPoint; -import org.aspectj.lang.Signature; -import org.aspectj.lang.annotation.Aspect; -import org.aspectj.lang.annotation.Before; -import org.aspectj.lang.reflect.MethodSignature; -import org.springframework.core.DefaultParameterNameDiscoverer; -import org.springframework.expression.EvaluationContext; -import org.springframework.expression.Expression; -import org.springframework.expression.ExpressionParser; -import org.springframework.expression.spel.standard.SpelExpressionParser; -import org.springframework.expression.spel.support.StandardEvaluationContext; -import org.springframework.stereotype.Component; -import org.yeshi.utils.NumberUtil; - -import com.yeshi.fanli.entity.bus.user.UserInfoExtra; -import com.yeshi.fanli.service.inter.integral.IntegralGetService; -import com.yeshi.fanli.service.inter.user.UserInfoExtraService; -import com.yeshi.fanli.service.inter.user.UserInfoModifyRecordService; -import com.yeshi.fanli.util.StringUtil; -import com.yeshi.fanli.util.ThreadUtil; -import com.yeshi.fanli.util.annotation.UserActive; - -import redis.clients.jedis.Jedis; -import redis.clients.jedis.JedisPool; - -/** - * 娲昏穬鐢ㄦ埛澶勭悊 - * - * @author Administrator - * - */ -@Component -@Aspect -public class ActiveUserAspect { - @Resource - private JedisPool jedisPool; - - @Resource - private UserInfoModifyRecordService userInfoModifyRecordService; - - @Resource - private UserInfoExtraService userInfoExtraService; - - @Resource - private IntegralGetService integralGetService; - - private ExpressionParser parser = new SpelExpressionParser(); - - private DefaultParameterNameDiscoverer nameDiscoverer = new DefaultParameterNameDiscoverer(); - - public String generateKeyBySpEL(String spELString, JoinPoint joinPoint) { - MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature(); - String[] paramNames = nameDiscoverer.getParameterNames(methodSignature.getMethod()); - Expression expression = parser.parseExpression(spELString); - EvaluationContext context = new StandardEvaluationContext(); - Object[] args = joinPoint.getArgs(); - for (int i = 0; i < args.length; i++) { - context.setVariable(paramNames[i], args[i]); - } - return expression.getValue(context).toString(); - } - - public static final String EDP = "execution(* com.yeshi.fanli.controller.client.*.*.*(..))"; - - @Before(EDP) - public void activeBefore(JoinPoint joinPoint) { - try { - Signature signature = joinPoint.getSignature(); - MethodSignature methodSignature = (MethodSignature) signature; - Method targetMethod = methodSignature.getMethod(); - Method realMethod = joinPoint.getTarget().getClass().getDeclaredMethod(joinPoint.getSignature().getName(), - targetMethod.getParameterTypes()); - if (realMethod.isAnnotationPresent(UserActive.class)) { - UserActive rs = realMethod.getAnnotation(UserActive.class); - String uidStr = generateKeyBySpEL(rs.uid(), joinPoint); - if (!StringUtil.isNullOrEmpty(uidStr) && NumberUtil.isNumeric(uidStr)) { - ThreadUtil.run(new Runnable() { - @Override - public void run() { - String key = "useractive-" + uidStr; - Jedis jedis = jedisPool.getResource(); - try { - if (jedis.setnx(key, "1") > 0) { - jedis.expire(key, 60 * 5);// 5鍒嗛挓鍐呬笉澶勭悊 - try { - // TODO 鐢ㄦ埛娲昏穬澶勭悊 - Long uid = Long.parseLong(uidStr); - userInfoModifyRecordService.syncBeforeInfo(uid); - UserInfoExtra extra = userInfoExtraService.getUserInfoExtra(uid); - if (extra != null && !StringUtil.isNullOrEmpty(extra.getInviteCode())) - integralGetService.addInviteActivate(uid); - } catch (Exception e) { - } - } - } finally { - jedisPool.returnResource(jedis); - } - } - }); - } - } - } catch (Exception e) { - - } - } - -} +package com.yeshi.fanli.aspect; + +import java.lang.reflect.Method; +import java.util.Date; + +import javax.annotation.Resource; + +import com.yeshi.fanli.util.RedisManager; +import org.aspectj.lang.JoinPoint; +import org.aspectj.lang.Signature; +import org.aspectj.lang.annotation.Aspect; +import org.aspectj.lang.annotation.Before; +import org.aspectj.lang.reflect.MethodSignature; +import org.springframework.core.DefaultParameterNameDiscoverer; +import org.springframework.expression.EvaluationContext; +import org.springframework.expression.Expression; +import org.springframework.expression.ExpressionParser; +import org.springframework.expression.spel.standard.SpelExpressionParser; +import org.springframework.expression.spel.support.StandardEvaluationContext; +import org.springframework.stereotype.Component; +import org.yeshi.utils.NumberUtil; + +import com.aliyun.openservices.ons.api.Message; +import com.aliyun.openservices.ons.api.Producer; +import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum; +import com.yeshi.fanli.dto.mq.user.body.UserActiveMQMsg; +import com.yeshi.fanli.service.inter.user.UserInfoExtraService; +import com.yeshi.fanli.service.inter.user.UserInfoModifyRecordService; +import com.yeshi.fanli.service.inter.user.integral.IntegralGetService; +import com.yeshi.fanli.util.Constant; +import com.yeshi.fanli.util.StringUtil; +import com.yeshi.fanli.util.ThreadUtil; +import com.yeshi.fanli.util.annotation.UserActive; +import com.yeshi.fanli.util.rocketmq.MQMsgBodyFactory; +import com.yeshi.fanli.util.rocketmq.MQTopicName; + +import redis.clients.jedis.Jedis; +import redis.clients.jedis.JedisPool; +import redis.clients.jedis.params.SetParams; + +/** + * 娲昏穬鐢ㄦ埛澶勭悊 + * + * @author Administrator + * + */ +@Component +@Aspect +public class ActiveUserAspect { + @Resource + private RedisManager redisManager; + + private ExpressionParser parser = new SpelExpressionParser(); + + private DefaultParameterNameDiscoverer nameDiscoverer = new DefaultParameterNameDiscoverer(); + + public String generateKeyBySpEL(String spELString, JoinPoint joinPoint) { + MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature(); + String[] paramNames = nameDiscoverer.getParameterNames(methodSignature.getMethod()); + Expression expression = parser.parseExpression(spELString); + EvaluationContext context = new StandardEvaluationContext(); + Object[] args = joinPoint.getArgs(); + for (int i = 0; i < args.length; i++) { + context.setVariable(paramNames[i], args[i]); + } + return expression.getValue(context).toString(); + } + + public static final String EDP = "execution(* com.yeshi.fanli.controller.client.*.*.*(..))"; + + @Before(EDP) + public void activeBefore(JoinPoint joinPoint) { + try { + Signature signature = joinPoint.getSignature(); + MethodSignature methodSignature = (MethodSignature) signature; + Method targetMethod = methodSignature.getMethod(); + Method realMethod = joinPoint.getTarget().getClass().getDeclaredMethod(joinPoint.getSignature().getName(), + targetMethod.getParameterTypes()); + if (realMethod.isAnnotationPresent(UserActive.class)) { + UserActive rs = realMethod.getAnnotation(UserActive.class); + String uidStr = generateKeyBySpEL(rs.uid(), joinPoint); + if (!StringUtil.isNullOrEmpty(uidStr) && NumberUtil.isNumeric(uidStr)) { + ThreadUtil.run(new Runnable() { + @Override + public void run() { + String key = "useractive-" + uidStr; + Jedis jedis =redisManager.getJedis(); + try { + if (!StringUtil.isNullOrEmpty(jedis.set(key, "1", new SetParams().nx().ex(Constant.IS_TEST?10:300)))) { + try { +// Long uid = Long.parseLong(uidStr); +// if (!Constant.IS_TEST) { // 娲昏穬閫氱煡 +// UserActiveMQMsg msg = new UserActiveMQMsg(uid, new Date()); +// Message message = MQMsgBodyFactory.create(MQTopicName.TOPIC_USER, UserTopicTagEnum.userActve, msg); +// message.setStartDeliverTime(System.currentTimeMillis()+1000*10L);//10s鍚庡彂閫佹椿璺冩秷鎭� +// producer.send(message); +// } + } catch (Exception e) { + + } + } + } finally { + jedis.close(); + } + } + }); + } + } + } catch (Exception e) { + + } + } + +} -- Gitblit v1.8.0