Spring MVC自定义统一异常处理类,并且在控制台中输出错误日志

 在使用SimpleMappingExceptionResolver实现统一异常处理后(参考Spring MVC的异常统一处理方法),发现出现异常时,log4j无法在控制台输出错误日志。因此需要自定义一个继承至SimpleMappingExceptionResolver的RrtongMappingExceptionResolver类,在RrtongMappingExceptionResolver中通过log.error(ex.getMessage())的方式输出日志到控制台上。以下是具体的配置和RrtongMappingExceptionResolver的实现。

         配置自定义的统一异常处理类RrtongMapping

    
      
       
     
       
       
     
       
       
     
       
    
     
       
        
      
        
            
       
       
        
        ../../exception/error-interface
       
         
            
       
         
            
       
       
        
        ../../exception/errorPage
       
         
        
      
        
    
     
       
       
     
            
            
      
             
                
       
       
        
        500
       
              
                
       
       
        
        404
       
              
            
      
             
       
     
               
    
     
       
    
     
       
    
     
       
    
     
       

    
      
ExceptionResolver


public class RrtongMappingExceptionResolver extends SimpleMappingExceptionResolver{  
    private final static Logger log = LoggerFactory.getLogger(RrtongMappingExceptionResolver.class);   
              
    @Override  
    protected ModelAndView doResolveException(HttpServletRequest request, HttpServletResponse response,  
            Object handler, Exception ex) {  
        Map
    
    
     
      model = new HashMap
     
     
      
      ();  
        model.put("ex", ex);  
        ModelAndView modelAndView = new ModelAndView("../../exception/errorPage",model);  
          
        /*错误日志输出到控制台*/  
        log.error(ex.getMessage());  
                  
        return modelAndView;  
    }  
}  
     
     
    
    


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值