From 10b47e7355ca507f8592c4c97acfd7deccc0f538 Mon Sep 17 00:00:00 2001
From: 13693261870 <252740454@qq.com>
Date: 星期三, 26 十月 2022 17:31:37 +0800
Subject: [PATCH] 1

---
 src/main/java/com/lf/server/interceptor/AuthInterceptor.java |   62 +++++++++++++++++++++++++++++-
 1 files changed, 59 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/lf/server/interceptor/AuthInterceptor.java b/src/main/java/com/lf/server/interceptor/AuthInterceptor.java
index 2b49a65..6fc779c 100644
--- a/src/main/java/com/lf/server/interceptor/AuthInterceptor.java
+++ b/src/main/java/com/lf/server/interceptor/AuthInterceptor.java
@@ -2,11 +2,11 @@
 
 import com.alibaba.fastjson.JSON;
 import com.lf.server.entity.all.*;
+import com.lf.server.entity.sys.TokenEntity;
 import com.lf.server.entity.sys.UserEntity;
 import com.lf.server.helper.StringHelper;
 import com.lf.server.helper.WebHelper;
 import com.lf.server.service.all.SysService;
-import com.lf.server.service.sys.TokenService;
 import org.apache.commons.logging.Log;
 import org.apache.commons.logging.LogFactory;
 import org.springframework.context.annotation.Configuration;
@@ -35,6 +35,12 @@
 
     private static final String NO_AUTH = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.NO_AUTH_ERROR, "鏃犳潈闄愯闂�"));
 
+    private static final String IP_NULL = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.UNAUTHORIZED, "IP鍦板潃涓虹┖"));
+
+    private static final String BLACK_LIST = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.UNAUTHORIZED, "璇P鍏ラ粦鍚嶅崟"));
+
+    private static final String ILLEGAL_TOKEN = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.UNAUTHORIZED, "浠ょ墝鏉ユ簮闈炴硶"));
+
     public AuthInterceptor(SysService sysService) {
         this.sysService = sysService;
     }
@@ -51,19 +57,33 @@
                 return true;
             }
 
+            // 鑾峰彇浠ょ墝
             String token = WebHelper.getToken(request);
             if (StringHelper.isNull(token)) {
                 return WebHelper.write2Page(response, NO_TOKEN);
             }
 
-            //String ip = WebHelper.getIpAddress(request);
-            //List<String> blackList=
+            // 鑾峰彇IP锛屾鏌ラ粦鍚嶅崟锛屾鏌ョ櫧鍚嶅崟锛屾鏌P涓�鑷存��
+            String ip = WebHelper.getIpAddress(request);
+            if (StringHelper.isEmpty(ip)) {
+                return WebHelper.write2Page(response, IP_NULL);
+            }
+            if (!checkBlackList(ip, request)) {
+                return WebHelper.write2Page(response, BLACK_LIST);
+            }
+            if (!checkWhiteList(ip, request)) {
+                if (!checkIpSource(ip, token)) {
+                    return WebHelper.write2Page(response, ILLEGAL_TOKEN);
+                }
+            }
 
+            // 鑾峰彇鐢ㄦ埛浠ょ墝
             UserEntity ue = sysService.tokenService.getCurrentUser(request);
             if (ue == null) {
                 return WebHelper.write2Page(response, NO_LOGIN);
             }
 
+            // 妫�鏌ョ敤鎴稩D鏄惁绂佺敤
             if (sysService.tokenService.isUidDisable(ue)) {
                 return WebHelper.write2Page(response, USER_LOCK);
             }
@@ -113,4 +133,40 @@
 
         return false;
     }
+
+    /**
+     * 妫�鏌ラ粦鍚嶅崟
+     */
+    private boolean checkBlackList(String ip, HttpServletRequest request) {
+        List<String> blackList = sysService.blacklistService.selectIpList(1);
+        if (blackList == null || blackList.isEmpty()) {
+            return true;
+        }
+        if (blackList.contains(ip)) {
+            return false;
+        }
+
+        return true;
+    }
+
+    /**
+     * 妫�鏌ョ櫧鍚嶅崟
+     */
+    private boolean checkWhiteList(String ip, HttpServletRequest request) {
+        List<String> whiteList = sysService.blacklistService.selectIpList(2);
+        if (whiteList == null || whiteList.isEmpty()) {
+            return true;
+        }
+
+        return whiteList.contains(ip);
+    }
+
+    /**
+     * 妫�鏌P涓�鑷存��
+     */
+    private boolean checkIpSource(String ip, String token) {
+        TokenEntity te = sysService.tokenService.getEntityByToken(token);
+
+        return te.getIp().equals(ip);
+    }
 }

--
Gitblit v1.9.3