12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- package org.jeecg.config.shiro.filters;
- import javax.servlet.ServletRequest;
- import javax.servlet.ServletResponse;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.apache.shiro.subject.Subject;
- import org.apache.shiro.web.filter.AccessControlFilter;
- import lombok.extern.slf4j.Slf4j;
- /**
- * @Author Scott
- * @create 2019-02-01 15:56
- * @desc 鉴权请求URL访问权限拦截器
- */
- @Slf4j
- public class ResourceCheckFilter extends AccessControlFilter {
- private String errorUrl;
- public String getErrorUrl() {
- return errorUrl;
- }
- public void setErrorUrl(String errorUrl) {
- this.errorUrl = errorUrl;
- }
- /**
- * 表示是否允许访问 ,如果允许访问返回true,否则false;
- *
- * @param servletRequest
- * @param servletResponse
- * @param o 表示写在拦截器中括号里面的字符串 mappedValue 就是 [urls] 配置中拦截器参数部分
- * @return
- * @throws Exception
- */
- @Override
- protected boolean isAccessAllowed(ServletRequest servletRequest, ServletResponse servletResponse, Object o) throws Exception {
- Subject subject = getSubject(servletRequest, servletResponse);
- String url = getPathWithinApplication(servletRequest);
- log.info("当前用户正在访问的 url => " + url);
- return subject.isPermitted(url);
- }
- /**
- * onAccessDenied:表示当访问拒绝时是否已经处理了; 如果返回 true 表示需要继续处理; 如果返回 false
- * 表示该拦截器实例已经处理了,将直接返回即可。
- *
- * @param servletRequest
- * @param servletResponse
- * @return
- * @throws Exception
- */
- @Override
- protected boolean onAccessDenied(ServletRequest servletRequest, ServletResponse servletResponse) throws Exception {
- log.info("当 isAccessAllowed 返回 false 的时候,才会执行 method onAccessDenied ");
- HttpServletRequest request = (HttpServletRequest) servletRequest;
- HttpServletResponse response = (HttpServletResponse) servletResponse;
- response.sendRedirect(request.getContextPath() + this.errorUrl);
- // 返回 false 表示已经处理,例如页面跳转啥的,表示不在走以下的拦截器了(如果还有配置的话)
- return false;
- }
- }
|