From 69a1b3bf45738f048361ee4ccb6bdc64fce35720 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期三, 12 三月 2025 11:31:46 +0800
Subject: [PATCH] 更新

---
 server/system_service/src/main/java/com/doumee/config/jwt/JwtTokenUtil.java |  247 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 247 insertions(+), 0 deletions(-)

diff --git a/server/system_service/src/main/java/com/doumee/config/jwt/JwtTokenUtil.java b/server/system_service/src/main/java/com/doumee/config/jwt/JwtTokenUtil.java
new file mode 100644
index 0000000..bd8d38a
--- /dev/null
+++ b/server/system_service/src/main/java/com/doumee/config/jwt/JwtTokenUtil.java
@@ -0,0 +1,247 @@
+package com.doumee.config.jwt;
+
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
+import com.doumee.biz.system.SystemDictDataBiz;
+import com.doumee.service.business.third.model.LoginUserInfo;
+import com.doumee.core.utils.Constants;
+import com.doumee.core.utils.HttpsUtil;
+import com.doumee.dao.system.SystemUserMapper;
+import com.doumee.dao.system.model.SystemUser;
+import io.jsonwebtoken.Jwts;
+import io.jsonwebtoken.SignatureAlgorithm;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.http.HttpEntity;
+import org.apache.http.HttpResponse;
+import org.apache.http.client.HttpClient;
+import org.apache.http.client.methods.HttpGet;
+import org.apache.http.impl.client.HttpClientBuilder;
+import org.apache.http.util.EntityUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.stereotype.Component;
+
+import javax.annotation.Resource;
+import java.io.IOException;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.concurrent.TimeUnit;
+
+@Component
+@Slf4j
+public class JwtTokenUtil {
+
+    @Autowired
+    private RedisTemplate<String,Object> redisTemplate;
+    @Resource
+    private JwtProperties jwtProperties;
+    @Autowired
+    private SystemDictDataBiz systemDictDataBiz ;
+    @Autowired
+    private SystemUserMapper systemUserMapper;
+    /**
+     * 鐢熸垚token浠ょ墝
+     *
+     * @param payloads 浠ょ墝涓惡甯︾殑闄勫姞淇℃伅
+     * @return 浠oken鐗�
+     */
+    public String generateToken( LoginUserInfo payloads) {
+        if(payloads == null){
+            return  null;
+        }
+        payloads.setLoginDate(new Date());
+        Map<String,Object> map = new HashMap<>();
+        map.put("id",payloads.getId());
+//        Map<String,Object> map =   BeanUtil.beanToMap(payloads);
+        return generateTokenDo(payloads);
+    }
+
+    /**
+     * 浠庝护鐗屼腑鑾峰彇鐢ㄦ埛鍚�
+     *
+     * @param token 浠ょ墝
+     * @return 鐢ㄦ埛鍚�
+     */
+    public String getUsernameFromToken(String token) {
+        String username;
+        try {
+            LoginUserInfo claims = getClaimsFromToken(token);
+            username = claims.getUsername();
+        } catch (Exception e) {
+            username = null;
+        }
+        return username;
+    }
+    public LoginUserInfo getUserInfoByToken(String token) {
+        try {
+            LoginUserInfo claims = getClaimsFromToken(token);
+            return claims;
+        } catch (Exception e) {
+           e.printStackTrace();
+        }
+        return null;
+    }
+
+    /**
+     * 鍒ゆ柇浠ょ墝鏄惁杩囨湡
+     *
+     * @param token 浠ょ墝
+     * @return 鏄惁杩囨湡
+     */
+    public Boolean isTokenExpired(String token) {
+        try {
+            LoginUserInfo claims = getClaimsFromToken(token);
+            Date expiration = //claims.getLoginDate();
+            new Date(claims.getLoginDate().getTime() + jwtProperties.getExpiration());
+            return expiration.before(new Date());
+        } catch (Exception e) {
+            //楠岃瘉JWT绛惧悕澶辫触绛夊悓浜庝护鐗岃繃鏈�
+            return true;
+        }
+    }
+
+    /**
+     * 鍒锋柊浠ょ墝
+     *
+     * @param token 鍘熶护鐗�
+     * @return 鏂颁护鐗�
+     */
+    public String refreshToken(String token) {
+        String refreshedToken;
+        try {
+            LoginUserInfo claims = getClaimsFromToken(token);
+            claims.setLoginDate(new Date());
+            refreshedToken = generateTokenDo(claims);
+            if(refreshedToken!=null){
+                redisTemplate.delete(Constants.REDIS_TOKEN_KEY+token);//鍒犻櫎鑰佺殑token
+            }
+        } catch (Exception e) {
+            refreshedToken = null;
+        }
+        return refreshedToken;
+    }
+    /**
+     * 閫�鍑虹櫥闄�
+     *
+     * @param token 鍘熶护鐗�
+     * @return 鏂颁护鐗�
+     */
+    public void logout(String token) {
+        try {
+            //鐧诲嚭娴峰悍绯荤粺鏁版嵁
+            LoginUserInfo loginUserInfo = this.getUserInfoByToken(token);
+            String url = systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.HK_HTTPS).getCode() +
+                    systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.HK_HOST).getCode() +
+                    systemDictDataBiz.queryByCode(Constants.HK_PARAM,Constants.LOGIN_OUT_URL).getCode();
+            if(StringUtils.isNotBlank(loginUserInfo.getHkMenuToken())){
+                log.info("璋冭捣娴峰悍閫�鍑虹櫥褰�=======================>"+url+"?token="+loginUserInfo.getHkMenuToken());
+//                this.hkLoginOut(url+"?token="+loginUserInfo.getHkMenuToken());
+                HttpsUtil.get(url+"?token="+loginUserInfo.getHkMenuToken(),true);
+            }
+            //鍒犻櫎鑰佺殑token
+            redisTemplate.delete(Constants.REDIS_TOKEN_KEY+token);
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+
+    public void logoutForH5(String token) {
+        try {
+            //鐧诲嚭娴峰悍绯荤粺鏁版嵁
+            LoginUserInfo loginUserInfo = this.getUserInfoByToken(token);
+            //鍒犻櫎鑰佺殑token
+            redisTemplate.delete(Constants.REDIS_TOKEN_KEY+token);
+            systemUserMapper.update(null,new UpdateWrapper<SystemUser>().lambda().set(SystemUser::getOpenid,null)
+                    .eq(SystemUser::getId,loginUserInfo.getId()));
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+    public void hkLoginOut(String url){
+        try {
+            // 鍒涘缓HttpClient瀵硅薄
+            HttpClient httpClient = HttpClientBuilder.create().build();
+            // 鍒涘缓HttpGet瀵硅薄锛屾寚瀹氳璁块棶鐨刄RL鍦板潃
+            HttpGet httpGet = new HttpGet(url);
+            // 鍙戦�丟ET璇锋眰锛岃幏鍙栧搷搴�
+            HttpResponse response = httpClient.execute(httpGet);
+            // 鑾峰彇鍝嶅簲鐘舵�佺爜
+            int statusCode = response.getStatusLine().getStatusCode();
+            // 鍒ゆ柇璇锋眰鏄惁鎴愬姛
+            if (statusCode == 200) {
+                // 鑾峰彇鍝嶅簲鍐呭
+                HttpEntity entity = response.getEntity();
+                String responseContent = EntityUtils.toString(entity, "UTF-8");
+                System.out.println(responseContent);
+                log.info("璋冭捣娴峰悍閫�鍑虹櫥褰曡繑鍥炰俊鎭�=======================>"+responseContent);
+            } else {
+                System.out.println("璇锋眰澶辫触锛屽搷搴旂爜锛�" + statusCode);
+            }
+        } catch (IOException e) {
+            e.printStackTrace();
+        }
+    }
+
+
+    /**
+     * 楠岃瘉浠ょ墝
+     *
+     * @param token       浠ょ墝
+     * @param userId  鐢ㄦ埛Id鐢ㄦ埛鍚�
+     * @return 鏄惁鏈夋晥
+     */
+    public Boolean validateToken(String token, String userId) {
+
+        String username = getUsernameFromToken(token);
+        return (username.equals(userId) && !isTokenExpired(token));
+    }
+
+
+    /**
+     * 浠巆laims鐢熸垚浠ょ墝,濡傛灉鐪嬩笉鎳傚氨鐪嬭皝璋冪敤瀹�
+     *
+     * @return 浠ょ墝
+     */
+    private String generateTokenDo(LoginUserInfo userInfo) {
+        Map<String, Object> claims = new HashMap<>();
+        claims.put("id",userInfo.getId());
+        Date expirationDate = new Date(System.currentTimeMillis() + jwtProperties.getExpiration());
+        String token = Jwts.builder().setClaims(claims)
+                .setExpiration(expirationDate)
+                .signWith(SignatureAlgorithm.HS512, jwtProperties.getSecret())
+                .compact();
+        redisTemplate.opsForValue().set(Constants.REDIS_TOKEN_KEY+token,JSONObject.toJSONString(userInfo),jwtProperties.getExpiration(), TimeUnit.MILLISECONDS);
+        return token;
+    }
+
+
+    /**
+     * 浠庝护鐗屼腑鑾峰彇鏁版嵁澹版槑,楠岃瘉JWT绛惧悕
+     *
+     * @param token 浠ょ墝
+     * @return 鏁版嵁澹版槑
+     */
+    private LoginUserInfo getClaimsFromToken(String token) {
+        LoginUserInfo claims;
+        try {
+            String userInfo = (String) redisTemplate.opsForValue().get(Constants.REDIS_TOKEN_KEY+token);
+            claims = JSONObject.toJavaObject(JSONObject.parseObject(userInfo),LoginUserInfo.class);
+        } catch (Exception e) {
+            claims = null;
+        }
+        return claims;
+    }
+
+    /**
+     * 鍚戝悗寤朵几鏈夋晥鏈熶繚鎸佷細璇濈户缁�
+     * @param token
+     */
+
+    public void refreshTokenTime(String token ) {
+        redisTemplate.expire(Constants.REDIS_TOKEN_KEY+token,jwtProperties.getExpiration(), TimeUnit.MILLISECONDS);
+//        redisTemplate.opsForValue().set(Constants.REDIS_TOKEN_KEY+token,usrerInfo,jwtProperties.getExpiration(), TimeUnit.MILLISECONDS);
+    }
+}
\ No newline at end of file

--
Gitblit v1.9.3