From 8b7e2c47b56bfe506ffd32b4f6268c5525248d7f Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Thu, 08 Dec 2022 17:37:11 +0800
Subject: [PATCH] 20221130
---
src/main/java/cc/mrbird/febs/common/interceptor/LoginInterceptor.java | 47 ++++++++++++++++++++++++++++++++++++++---------
1 files changed, 38 insertions(+), 9 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/common/interceptor/LoginInterceptor.java b/src/main/java/cc/mrbird/febs/common/interceptor/LoginInterceptor.java
index 8ed6ab5..17bb17c 100644
--- a/src/main/java/cc/mrbird/febs/common/interceptor/LoginInterceptor.java
+++ b/src/main/java/cc/mrbird/febs/common/interceptor/LoginInterceptor.java
@@ -5,6 +5,7 @@
import cc.mrbird.febs.common.utils.RedisUtils;
import cc.mrbird.febs.common.utils.SpringContextUtil;
import cc.mrbird.febs.dapp.entity.DappMemberEntity;
+import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.asymmetric.KeyType;
import cn.hutool.crypto.asymmetric.RSA;
@@ -31,21 +32,38 @@
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
- System.out.println(request.getHeader(":path"));
- String headerToken = request.getHeader("key");
+// System.out.println(request.getHeader(":path"));
+ if ("OPTIONS".equals(request.getMethod().toUpperCase())) {
+ return true;
+ }
+ String headerToken = request.getHeader("token");
if (StringUtils.isBlank(headerToken)) {
responseUnAuth(response);
return false;
}
- String userJsonStr = redisUtils.getString(headerToken);
+ String token = resolveToken(headerToken);
+ if (token == null || AppContants.TIME_OUT.equals(token)) {
+ responseUnAuth(response);
+ return false;
+ }
+
+ if(ObjectUtil.isEmpty(redisUtils.getString(token))){
+ responseUnAuth(response);
+ return false;
+ }
+
+ String userJsonStr = redisUtils.getString(token);
+
if (StringUtils.isBlank(userJsonStr)) {
responseUnAuth(response);
return false;
}
DappMemberEntity member = JSON.parseObject(userJsonStr, DappMemberEntity.class);
-
request.getSession().setAttribute("member", member);
+ String id = request.getSession().getId();
+
+
return true;
}
@@ -69,11 +87,11 @@
try {
RSA rsa = new RSA(AppContants.PRIVATE_KEY, null);
String[] tokens = StrUtil.split(rsa.decryptStr(token, KeyType.PrivateKey), "_");
- if (verifyTokenExpired(Long.parseLong(tokens[1]))) {
+// if (verifyTokenExpired(Long.parseLong(tokens[1]))) {
return tokens[0];
- } else {
- return AppContants.TIME_OUT;
- }
+// } else {
+// return AppContants.TIME_OUT;
+// }
} catch (Exception e) {
log.error("#解析token异常#", e);
return null;
@@ -84,8 +102,19 @@
boolean isDebug = false;
if (!isDebug) {
long currentTime = System.currentTimeMillis();
- return currentTime - time <= 10000;
+ return currentTime - time <= 3600000;
}
return true;
}
+
+ public static void main(String[] args) {
+ String token = "LevMUYpG9zdhHcDuTyfCovvbC7SBrMQG5xdVMsFoFr+wGXeToiy3fextPC9fmJtM0cWYyrs+ktvoDNvKPwFMjAikCvVwm9bjSeX9457mexw8FotWUZqc6WejSP0YDXYKrSix5JtgI7TlKJ154K0gau941+b8czb3SUZhY0kgfgQ=";
+ RSA rsa = new RSA(AppContants.PRIVATE_KEY, null);
+ String s = rsa.decryptStr(token, KeyType.PrivateKey);
+
+ System.out.print(s);
+// String[] tokens = StrUtil.split(rsa.decryptStr(token, KeyType.PrivateKey), "_");
+// System.out.print(tokens[0]);
+// System.out.print(tokens[1]);
+ }
}
--
Gitblit v1.9.1