From f5e6133809c553cfd9fb28ee61019927c547c374 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Wed, 08 Dec 2021 15:58:33 +0800
Subject: [PATCH] 20211208  fish

---
 src/main/java/com/xcong/excoin/common/LoginUserUtils.java |   52 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 52 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/common/LoginUserUtils.java b/src/main/java/com/xcong/excoin/common/LoginUserUtils.java
index dbdd9d2..a59ba96 100644
--- a/src/main/java/com/xcong/excoin/common/LoginUserUtils.java
+++ b/src/main/java/com/xcong/excoin/common/LoginUserUtils.java
@@ -1,8 +1,20 @@
 package com.xcong.excoin.common;
 
+import cn.hutool.core.util.StrUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.xcong.excoin.common.contants.AppContants;
+import com.xcong.excoin.common.exception.GlobalException;
 import com.xcong.excoin.modules.member.entity.MemberEntity;
+import com.xcong.excoin.utils.RedisUtils;
+import com.xcong.excoin.utils.SpringContextHolder;
 import lombok.extern.slf4j.Slf4j;
+import org.springframework.http.HttpRequest;
+import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
+import org.springframework.security.core.Authentication;
 import org.springframework.security.core.context.SecurityContextHolder;
+
+import javax.servlet.http.HttpServletRequest;
+import java.util.ArrayList;
 
 /**
  * 登陆用户工具类
@@ -17,9 +29,49 @@
 
     public static MemberEntity getAppLoginUser() {
         if (SecurityContextHolder.getContext().getAuthentication().getPrincipal().equals(ANON)) {
+            throw new GlobalException("无法获取登陆信息");
+        } else {
+            return (MemberEntity) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
+        }
+    }
+
+    public static String getAppLoginUserToken() {
+        return (String) SecurityContextHolder.getContext().getAuthentication().getCredentials();
+    }
+
+    public static void resetAppLoginUser(MemberEntity memberEntity) {
+        String token = getAppLoginUserToken();
+        RedisUtils redisUtils = SpringContextHolder.getBean(RedisUtils.class);
+        String jsonStr = redisUtils.getString(AppContants.PC_LOGIN_PREFIX + token);
+        if (StrUtil.isNotBlank(jsonStr)) {
+            redisUtils.set(AppContants.PC_LOGIN_PREFIX + token, JSONObject.toJSONString(memberEntity));
+        } else {
+            redisUtils.set(AppContants.APP_LOGIN_PREFIX + token, JSONObject.toJSONString(memberEntity));
+        }
+    }
+
+    /**
+     * mybatis 拦截器专用
+     *
+     * @return MemberEntity
+     */
+    public static MemberEntity getUser() {
+        if (SecurityContextHolder.getContext().getAuthentication() == null) {
+            return null;
+        }
+
+        if (SecurityContextHolder.getContext().getAuthentication().getPrincipal().equals(ANON)) {
             return null;
         } else {
             return (MemberEntity) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
         }
     }
+
+    public static boolean isBrowser(HttpServletRequest request) {
+        String userAgent = request.getHeader("user-agent");
+        if (userAgent.toLowerCase().contains("mobile") || userAgent.contains("CFNetwork") || userAgent.toLowerCase().contains("okhttp")) {
+            return false;
+        }
+        return true;
+    }
 }

--
Gitblit v1.9.1