| | |
| | | import com.terra.common.entity.all.HttpStatus; |
| | | import com.terra.common.entity.all.ResponseMsg; |
| | | import com.terra.common.entity.all.StaticData; |
| | | import com.terra.common.entity.lf.TokenPo; |
| | | import com.terra.common.entity.lf.UserPo; |
| | | import com.terra.common.helper.StringHelper; |
| | | import com.terra.common.helper.WebHelper; |
| | |
| | | import org.springframework.web.method.HandlerMethod; |
| | | import org.springframework.web.servlet.HandlerInterceptor; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.util.List; |
| | |
| | | */ |
| | | @Configuration |
| | | public class AuthInterceptor implements HandlerInterceptor { |
| | | private CommonService commonService; |
| | | private final CommonService commonService; |
| | | |
| | | private static final Log log = LogFactory.getLog(AuthInterceptor.class); |
| | | |
| | |
| | | } |
| | | |
| | | // 3.è·åç¨æ·ä»¤ç |
| | | UserPo ue = commonService.getUserByToken(token); //new UserPo(); //sysService.tokenService.getUserByToken(token); |
| | | UserPo ue = commonService.getUserByToken(token); |
| | | if (null == ue) { |
| | | return WebHelper.writeStr2Page(response, NO_LOGIN); |
| | | } |
| | |
| | | } |
| | | |
| | | // 6.adminè·³è¿æéæ£æµ |
| | | if (StaticData.ADMIN.equals(ue.getUid())) { |
| | | return true; |
| | | //if (StaticData.ADMIN.equals(ue.getUid())) { |
| | | // return true; |
| | | //} |
| | | |
| | | // 7.æ£æ¥ç¨æ·IDæ¯å¦ç¦ç¨ |
| | | if (commonService.isUidDisable(ue)) { |
| | | return WebHelper.writeStr2Page(response, USER_LOCK); |
| | | } |
| | | |
| | | // 7.æ£æ¥ç½åååIPä¸è´æ§ |
| | | // 8.æ£æ¥ç½åååIPä¸è´æ§ |
| | | if (!checkWhiteList(ip, request)) { |
| | | if (!checkIpSource(ip, token)) { |
| | | return WebHelper.writeStr2Page(response, ILLEGAL_TOKEN); |
| | | } |
| | | } |
| | | |
| | | // 8.æ£æ¥ç¨æ·IDæ¯å¦ç¦ç¨ |
| | | //if (sysService.tokenService.isUidDisable(ue)) { |
| | | // return WebHelper.writeStr2Page(response, USER_LOCK); |
| | | //} |
| | | |
| | | // 9.æéæ ¡éª |
| | | if (!checkPerms(ue, request)) { |
| | |
| | | } |
| | | |
| | | /** |
| | | * æ£æ¥æé |
| | | * æ£æ¥ç½åå |
| | | */ |
| | | private boolean checkPerms(UserPo ue, HttpServletRequest request) { |
| | | return true; |
| | | private boolean checkWhiteList(String ip, HttpServletRequest request) { |
| | | List<String> whiteList = commonService.selectIpList(2); |
| | | if (whiteList == null || whiteList.isEmpty()) { |
| | | return false; |
| | | } |
| | | |
| | | // List<String> list = null; //sysService.permsService.selectPerms(ue.getUid()); |
| | | // if (list == null || list.size() == 0) { |
| | | // return false; |
| | | // } |
| | | // |
| | | // String url = request.getRequestURI(); |
| | | // for (String perm : list) { |
| | | // if (url.contains(perm)) { |
| | | // return true; |
| | | // } |
| | | // } |
| | | // |
| | | // return false; |
| | | return whiteList.contains(ip); |
| | | } |
| | | |
| | | /** |
| | | * æ£æ¥é»åå |
| | | */ |
| | | private boolean checkBlackList(String ip, HttpServletRequest request) { |
| | | List<String> blackList = null; // sysService.blacklistService.selectIpList(1); |
| | | List<String> blackList = commonService.selectIpList(1); |
| | | if (blackList == null || blackList.isEmpty()) { |
| | | return true; |
| | | } |
| | |
| | | } |
| | | |
| | | /** |
| | | * æ£æ¥ç½åå |
| | | */ |
| | | private boolean checkWhiteList(String ip, HttpServletRequest request) { |
| | | List<String> whiteList = null; // sysService.blacklistService.selectIpList(2); |
| | | if (whiteList == null || whiteList.isEmpty()) { |
| | | return false; |
| | | } |
| | | |
| | | return whiteList.contains(ip); |
| | | } |
| | | |
| | | /** |
| | | * æ£æ¥IPä¸è´æ§ï¼åºå®ä»¤ç䏿£æ¥ |
| | | */ |
| | | private boolean checkIpSource(String ip, String token) { |
| | | //TokenEntity te = sysService.tokenService.getEntityByToken(token); |
| | | TokenPo te = commonService.getTokenPo(token); |
| | | |
| | | //return StaticData.I1 == te.getType() || te.getIp().equals(ip); |
| | | return StaticData.I1 == te.getType() || te.getIp().equals(ip); |
| | | } |
| | | |
| | | return true; |
| | | /** |
| | | * æ£æ¥æé |
| | | */ |
| | | private boolean checkPerms(UserPo ue, HttpServletRequest request) { |
| | | List<String> list = commonService.selectPerms(ue.getUid()); |
| | | if (list == null || list.size() == 0) { |
| | | return false; |
| | | } |
| | | |
| | | String url = request.getRequestURI(); |
| | | for (String perm : list) { |
| | | if (url.contains(perm)) { |
| | | return true; |
| | | } |
| | | } |
| | | |
| | | return false; |
| | | } |
| | | } |