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