¶Ô±ÈÐÂÎļþ |
| | |
| | | package com.lf.server.interceptor; |
| | | |
| | | 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 org.apache.commons.logging.Log; |
| | | import org.apache.commons.logging.LogFactory; |
| | | import org.springframework.context.annotation.Configuration; |
| | | import org.springframework.web.method.HandlerMethod; |
| | | import org.springframework.web.servlet.HandlerInterceptor; |
| | | |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.util.List; |
| | | |
| | | /** |
| | | * èº«ä»½è®¤è¯æ¦æªå¨ |
| | | * @author WWW |
| | | */ |
| | | @Configuration |
| | | public class AuthInterceptor implements HandlerInterceptor { |
| | | private SysService sysService; |
| | | |
| | | private static final Log log = LogFactory.getLog(AuthInterceptor.class); |
| | | |
| | | private static final String NO_TOKEN = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.TOKEN_ERROR, "æ¾ä¸å°ä»¤ç")); |
| | | |
| | | private static final String NO_LOGIN = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.NO_LOGIN_ERROR, "ç¨æ·æªç»å½")); |
| | | |
| | | private static final String USER_LOCK = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.USER_LOCK_ERROR, "ç¨æ·IDå·²ç¦ç¨")); |
| | | |
| | | 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, "该IPå
¥é»åå")); |
| | | |
| | | private static final String ILLEGAL_TOKEN = JSON.toJSONString(new ResponseMsg<String>(HttpStatus.UNAUTHORIZED, "ä»¤çæ¥æºéæ³")); |
| | | |
| | | public AuthInterceptor(SysService sysService) { |
| | | this.sysService = sysService; |
| | | } |
| | | |
| | | /** |
| | | * Controlleræ§è¡ä¹åæ§è¡ï¼å¦æè¿å弿¯trueå代表æ¾è¡ï¼è¿åfalseåæ¦æª |
| | | */ |
| | | @Override |
| | | public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) { |
| | | // noinspection AlibabaRemoveCommentedCode |
| | | try { |
| | | // éæ¹æ³ æ æ éææï¼æ éæ¦æª |
| | | if (!(handler instanceof HandlerMethod) || noNeedAuth(request)) { |
| | | return true; |
| | | } |
| | | |
| | | // è·å令ç |
| | | String token = WebHelper.getToken(request); |
| | | if (StringHelper.isNull(token)) { |
| | | return WebHelper.write2Page(response, NO_TOKEN); |
| | | } |
| | | |
| | | // è·åIPï¼æ£æ¥é»ååï¼æ£æ¥ç½ååï¼æ£æ¥IPä¸è´æ§ |
| | | 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); |
| | | } |
| | | |
| | | // æ£æ¥ç¨æ·IDæ¯å¦ç¦ç¨ |
| | | if (sysService.tokenService.isUidDisable(ue)) { |
| | | return WebHelper.write2Page(response, USER_LOCK); |
| | | } |
| | | |
| | | // æéæ ¡éª |
| | | if (!checkPerms(ue, request)) { |
| | | System.out.println("æ æé访é®ï¼" + request.getRequestURI().toLowerCase()); |
| | | return WebHelper.write2Page(response, NO_AUTH); |
| | | } |
| | | |
| | | return true; |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage(), ex); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * æ éææ |
| | | */ |
| | | private static boolean noNeedAuth(HttpServletRequest request) { |
| | | String uri = request.getRequestURI().toLowerCase(); |
| | | for (String page : StaticData.EXCLUDE_PATH) { |
| | | if (uri.contains(page)) { |
| | | return true; |
| | | } |
| | | } |
| | | |
| | | return false; |
| | | } |
| | | |
| | | /** |
| | | * æ£æ¥æé |
| | | */ |
| | | private boolean checkPerms(UserEntity ue, HttpServletRequest request) { |
| | | List<String> list = sysService.permsService.selectPerms(ue.getUid()); |
| | | if (list == null || list.size() == 0) { |
| | | return false; |
| | | } |
| | | |
| | | String url = request.getRequestURI(); |
| | | for (String perm : list) { |
| | | if (url.startsWith(perm)) { |
| | | return true; |
| | | } |
| | | } |
| | | |
| | | 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); |
| | | } |
| | | |
| | | /** |
| | | * æ£æ¥IPä¸è´æ§ |
| | | */ |
| | | private boolean checkIpSource(String ip, String token) { |
| | | TokenEntity te = sysService.tokenService.getEntityByToken(token); |
| | | |
| | | return te.getIp().equals(ip); |
| | | } |
| | | } |