栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Filter Interceptor Aop

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Filter Interceptor Aop

过滤器 拦截器 AOP切面
拦截颗粒:过滤器 > 拦截器 > AOP切面        【精细度反之】
拦截顺序:过滤器 》拦截器 》AOP切面

 

过滤器
        基于函数回调,依赖于servlet容器,无法注入Bean;拦截URL,拦截的最前沿,适合公用性强的拦截逻辑,对服务性能影响最小

        简单实现@"暴力屏蔽Cors跨越",过滤器的核心方法是doFilter,通过调整req于res实现过滤功能。

@Component
public class CorsFilter implements Filter {

    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse) res;
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, HEAD");
        response.setHeader("Access-Control-Max-Age", "3000");
        response.setHeader("Access-Control-Allow-Headers", "access-control-allow-origin, authority, content-type, version-info, X-Requested-With");
        chain.doFilter(req, res);
    }

}

拦截器
        基于java反射,不依赖于servlet容器,可以注入Bean;拦截URL,在过滤器之后拦截

        简单实现@"登录拦截",拦截器的核心方法是preHandle(前置拦截controller前)、postHandle(后置拦截 页面渲染之前)、afterCompletion(最终拦截 用于销毁关闭资源),通过调整req于res实现过滤功能。

public class LoginHandlerInterceptor implements HandlerInterceptorAdapter {
    
    @Resource
    private LoginCache loginCache;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        cookie[] cookies = request.getcookies();
        if (null != cookies && cookies.length >= 1) {
            for (cookie cookie : cookies) {
                if (cookie.getName().equals("token")) {
                    return loginCache.exist(cookie.getValue());
                }
            }
        }
        request.getRequestDispatcher("/").forward(request, response);
        return false;
    }
    
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        super.postHandle(request, response, handler, modelAndView);
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        super.afterCompletion(request, response, handler, ex);
    }
}


AOP切面
        基于java反射,拦截包、类、方法、参数

        简单实现@"controller日志"。

@Component
@Aspect
@Slf4j
public class ControllerLogAop {

    @Around("execution(public *  com.xxx.controller.*.*(..))")
    public Object aroundController(ProceedingJoinPoint point) throws Throwable {
        return writeLog(point);
    }
    private Object writeLog(ProceedingJoinPoint point) throws Throwable {
        String className = point.getTarget().getClass().getName();
        String methodName = point.getSignature().getName();

        String reqUrl = StringUtils.EMPTY;
        String reqMethod = StringUtils.EMPTY;

        RequestAttributes ra = RequestContextHolder.getRequestAttributes();
        ServletRequestAttributes sra = (ServletRequestAttributes) ra;
        HttpServletRequest request = sra.getRequest();

        if (request != null) {
            reqUrl = request.getRequestURL().toString();
            reqMethod = request.getMethod();
        }

        long beginTime = System.currentTimeMillis();
        Object result = null;
        Exception ex = null;
        try {
            result = point.proceed();
            return result;
        } catch (Exception e) {
            ex = e;
            throw e;
        } finally {
            long costTime = System.currentTimeMillis() - beginTime;
            if (ex != null) {
                log.error("[url: {}][method: {}][className: {}][methodName: {}][cost: {} ms][args: {}][发生异常]", reqUrl, reqMethod, className, methodName, costTime, point.getArgs(), ex);
            } else {
                log.info("[url: {}][method: {}][className: {}][methodName: {}][cost: {} ms][args: {}][return: {}]", reqUrl, reqMethod, className, methodName, costTime, point.getArgs(), new Gson().toJson(result));
            }
        }
    }

}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/489979.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号