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