栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Spring HandlerInterceptorAdapter postHandle是否得到保证?

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

Spring HandlerInterceptorAdapter postHandle是否得到保证?

您可以考虑合并 afterCompletion 内部的逻辑,即使在处理程序方法引发异常的情况下也将 调用
该逻辑。一个很好的在线例子

public class RequestProcessingTimeInterceptor extends HandlerInterceptorAdapter {    private static final Logger logger = LoggerFactory .getLogger(RequestProcessingTimeInterceptor.class);    @Override    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {        long startTime = System.currentTimeMillis();        logger.info("Request URL::" + request.getRequestURL().toString()     + ":: Start Time=" + System.currentTimeMillis());        request.setAttribute("startTime", startTime);        //if returned false, we need to make sure 'response' is sent        return true;    }    @Override    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {        System.out.println("Request URL::" + request.getRequestURL().toString()     + " Sent to Handler :: Current Time=" + System.currentTimeMillis());        //we can add attributes in the modelAndView and use that in the view page    }    @Override    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {        long startTime = (Long) request.getAttribute("startTime");        logger.info("Request URL::" + request.getRequestURL().toString()     + ":: End Time=" + System.currentTimeMillis());        logger.info("Request URL::" + request.getRequestURL().toString()     + ":: Time Taken=" + (System.currentTimeMillis() - startTime));    } }


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

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

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