码迷,mamicode.com
首页 > 其他好文 > 详细

全局异常处理

时间:2018-06-25 15:01:43      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:logger   pen   使用   resolve   Servle   c中   实现   分享   comm   

1.   全局异常处理

1.1. 处理思路

  技术分享图片

 

1.2. log4j日志配置文件

  slf4j是一个日志框架,是一个顶层的日志系统,底层实现可以是log4j也可以是commons-logging。在项目中使用顶层的slf4j接口。

  log4j是对抽象的slf4j的具体实现。

  classPath路径下创建文件 log4j.properties

log4j.rootLogger=INFO,A3,STDOUT

log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
log4j.appender.STDOUT.layout.ConversionPattern=[%p] [%l] %10.10c - %m%n

log4j.appender.A3=org.apache.log4j.RollingFileAppender
log4j.appender.A3.file=logs/server.log
log4j.appender.A3.MaxFileSize=1024KB
log4j.appender.A3.MaxBackupIndex=10
log4j.appender.A3.layout=org.apache.log4j.PatternLayout
log4j.appender.A3.layout.ConversionPattern=\n\n[%-5p] %d{yyyy-MM-dd HH\:mm\:ss,SSS} method\:%l%n%m%n

 

1.3. 创建全局异常处理器

 

public class GlobalExceptionReslover implements HandlerExceptionResolver {

    Logger logger = LoggerFactory.getLogger(GlobalExceptionReslover.class);
    
    @Override
    public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler,
            Exception ex) {
        //写日志文件
        logger.error("系统发生异常", ex);
        //发邮件、发短信
        //Jmail:可以查找相关的资料
        //需要在购买短信。调用第三方接口即可。
        //展示错误页面
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("message", "系统发生异常,请稍后重试");
        modelAndView.setViewName("error/exception");
        return modelAndView;
    }

}

 

 


 

1.4. Springmvc中配置异常处理器

 技术分享图片

全局异常处理

标签:logger   pen   使用   resolve   Servle   c中   实现   分享   comm   

原文地址:https://www.cnblogs.com/arjenlee/p/9223908.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!