springmvc 统一处理异常
-
1.自定义统一异常处理器
自定义Exception实现 HandlerExceptionResolver接口或继承AbstractHandlerExceptionResolver类
1.实现接口HandlerExceptionResolver
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354package
com.jay.platform.exception.handler;import
java.io.IOException;import
java.net.ConnectException;import
java.net.SocketTimeoutException;import
java.util.Date;import
javax.servlet.http.HttpServletRequest;import
javax.servlet.http.HttpServletResponse;import
org.apache.log4j.Logger;import
org.springframework.web.servlet.HandlerExceptionResolver;import
org.springframework.web.servlet.ModelAndView;import
com.jay.platform.exception.AjaxException;import
com.jay.platform.exception.BusinessException;/***
*
@ClassName: ExceptionHandler*
@Description: 统一异常处理 , 注意这里可以处理Controller层抛出的异常,但不处理Controller捕获的异常(Controller捕获的异常,这里不再处理)*
@author Jay He*
@date 2014年11月4日 上午10:22:11*
*/public
class
ExceptionHandlerimplements
HandlerExceptionResolver {private
static
final
Logger LOGGER = Logger.getLogger(ExceptionHandler.class);@Overridepublic
ModelAndView resolveException(HttpServletRequest request,HttpServletResponse
response, Object handler, Exception ex) {LOGGER.error(new
Date().toLocaleString() +"异常信息",
ex);if
(exinstanceof
NumberFormatException) {return
new
ModelAndView("exception/number");}
else
if
(exinstanceof
NullPointerException) {return
new
ModelAndView("exception/null");}
else
if
(exinstanceof
BusinessException) {return
new
ModelAndView("exception/business");}
else
if
(exinstanceof
SocketTimeoutException||
exinstanceof
ConnectException) {try
{response.getWriter().write("网络异常");}
catch
(IOException e) {e.printStackTrace();}return
new
ModelAndView("exception/net_error");}else
if(ex
instanceof
AjaxException){System.out.println("-=-=");}return
new
ModelAndView("exception/exception");}}2.继承AbstractHandlerExceptionResolver类
12345678910111213141516171819202122232425262728293031323334package
com.jay.platform.exception.handler;import
java.io.IOException;import
java.net.ConnectException;import
java.net.SocketTimeoutException;import
java.util.Date;import
javax.servlet.http.HttpServletRequest;import
javax.servlet.http.HttpServletResponse;import
org.apache.log4j.Logger;import
org.springframework.web.servlet.HandlerExceptionResolver;import
org.springframework.web.servlet.ModelAndView;import
org.springframework.web.servlet.handler.AbstractHandlerExceptionResolver;import
com.jay.platform.exception.AjaxException;import
com.jay.platform.exception.BusinessException;/***
*
@ClassName: ExceptionHandler*
@Description: 统一异常处理 , 注意这里可以处理Controller层抛出的异常,但不处理Controller捕获的异常(Controller捕获的异常,这里不再处理)*
@author Jay He*
@date 2014年11月4日 上午10:22:11*
*/public
class
ExceptionHandlerextends
AbstractHandlerExceptionResolver{private
static
final
Logger LOGGER = Logger.getLogger(ExceptionHandler.class);@Overrideprotected
ModelAndView doResolveException(HttpServletRequest request,HttpServletResponse
response, Object handler, Exception ex) {LOGGER.error(new Date().toLocaleString() + "异常信息", ex); if (ex instanceof NumberFormatException) { return new ModelAndView("exception/number"); } else if (ex instanceof NullPointerException) { return new ModelAndView("exception/null"); } else if (ex instanceof BusinessException) { return new ModelAndView("exception/business"); } else if (ex instanceof SocketTimeoutException || ex instanceof ConnectException) { try { response.getWriter().write("网络异常"); } catch (IOException e) { e.printStackTrace(); } return new ModelAndView("exception/net_error"); }else if(ex instanceof AjaxException){ System.out.println("-=-="); } return new ModelAndView("exception/exception");}}
1在配置文件中添加自定义异常处理模块
12<!--
Spring MVC的统一异常处理 --><bean
class="com.jay.platform.exception.handler.ExceptionHandler"
id="exceptionResolver">
</bean>错误页面展示:
error.jsp12<%@
page language="java"
contentType="text/html;
charset=UTF-8"pageEncoding="UTF-8"%>Error页面
出错信息
错误描述
${errorTips }
错误异常信息栈
${ex }
eception.jsp12<%@
page language="java"
contentType="text/html;
charset=UTF-8"pageEncoding="UTF-8"%>Exception页面
模块开发中,请稍后。。。。。。
2.基于@ControllerAdvice注解实现统一异常处理,可方便返回普通异常和Ajax异常信息
自定义Web层异常处理
WebExceptionHandler.java
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103package
com.jay.platform.exception.handler;import
java.io.IOException;import
java.net.ConnectException;import
java.net.SocketTimeoutException;import
javax.servlet.http.HttpServletRequest;import
javax.servlet.http.HttpServletResponse;import
org.apache.log4j.Logger;import
org.apache.shiro.authz.UnauthorizedException;import
org.springframework.http.HttpStatus;import
org.springframework.web.bind.ServletRequestUtils;import
org.springframework.web.bind.annotation.ControllerAdvice;import
org.springframework.web.bind.annotation.ExceptionHandler;import
org.springframework.web.bind.annotation.ResponseStatus;import
org.springframework.web.context.request.NativeWebRequest;import
org.springframework.web.servlet.ModelAndView;import
com.jay.platform.exception.AjaxException;import
com.jay.platform.utils.DateUtil;/***
@ClassName: WebExceptionHandler*
@Description: Web层异常处理器, -- 这里可以根据不同的异常,写多个方法去处理, 可以处理跳转页面请求,跳到异常指定的错误页,*
也可以处理Ajax请求,根据不通过异常,在页面输出不同的提示信息*
operateExp : 处理普通请求*
operateExpAjax : 处理Ajax请求*
@author Jay He*
@date 2015年5月27日 下午5:16:37*
*/@ControllerAdvicepublic
class
WebExceptionHandler {Logger
logger = Logger.getLogger(WebExceptionHandler.class);/**
如果抛出UnauthorizedException,将被该异常处理器截获来显示没有权限信息*/@ExceptionHandler({
UnauthorizedException.class
})@ResponseStatus(HttpStatus.UNAUTHORIZED)public
ModelAndView unauthenticatedException(NativeWebRequest request,UnauthorizedException
e) {ModelAndView
mv =new
ModelAndView();mv.addObject("exception",
e);mv.setViewName("base/exception/unauthorized");return
mv;}/***
@Title: operateExp*
@Description: 全局异常控制,记录日志*
任何一个方法发生异常,一定会被这个方法拦截到。然后,输出日志。封装Map并返回给页面显示错误信息:*
特别注意:返回给页面错误信息只在开发时才使用,上线后,要把错误页面去掉,只打印log日志即可,防止信息外漏*
@param: @param ex*
@param: @param request*
@return: String*
@throws:*/@ExceptionHandler(RuntimeException.class)public
String operateExp(RuntimeException ex, HttpServletRequest request) {logger.error(ex.getMessage(),
ex);logger.info("*************
------ 异常信息已记录("
+ DateUtil.getNow("yyyy-MM-dd
HH:mm:ss")+
")
------- ***********");request.setAttribute("errorTips",
ex.getMessage());request.setAttribute("ex",
ex);return
"exception/error";}/**
记录Ajax异常日志,并将错误Ajax错误信息传递(回写)给前台展示,*
前台的jQuery的Ajax请求error中,可以打印错误提示信息 -- data.responseText : 这里即是后台传递的错误提示*
eg:*
$.ajax({type
: 'get',dataType
: "json",url
: ctx + '/test/test',accept:"application/json",success
: function(data) {console.log(data);},error
: function(data, errorThrown) {console.log(data);alert("error"
+ data.responseText);}});*/@ExceptionHandler(AjaxException.class)public
void
operateExpAjax(AjaxException ex, HttpServletResponse response)throws
IOException {logger.error(ex.getMessage(),
ex);logger.info("*************
------ 异常信息已记录("
+ DateUtil.getNow("yyyy-MM-dd
HH:mm:ss")+
")
------- ***********");//将Ajax异常信息回写到前台,用于页面的提示response.getWriter().write("sorry,Ajax请求出错!!!");}@ExceptionHandler(ConnectException.class)public
void
operateExpNetException(ConnectException ex, HttpServletResponse response)
throws
IOException {logger.error(ex.getMessage(),
ex);logger.info("*************
------ 异常信息已记录("
+ DateUtil.getNow("yyyy-MM-dd
HH:mm:ss")+
")
------- ***********");//将Ajax异常信息回写到前台,用于页面的提示response.getWriter().write("sorry,网络连接出错!!!");}}异常测试
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465package
com.jay.platform.controller.test;import
java.net.ConnectException;import
java.util.HashMap;import
java.util.Map;import
org.springframework.stereotype.Component;import
org.springframework.stereotype.Controller;import
org.springframework.web.bind.annotation.RequestMapping;import
org.springframework.web.bind.annotation.RequestMethod;import
org.springframework.web.bind.annotation.ResponseBody;import
com.jay.platform.annotation.AjaxExceptionHandler;import
com.jay.platform.exception.AjaxException;@Component@Controller()@RequestMapping("exception")public
class
ExceptionHandlerTestController {@RequestMapping("test")public
String getIt(){return
"exception/test/test";}@RequestMapping(value="/common",method=RequestMethod.GET)public
Map<string, object="">
commonExcetion()throws
RuntimeException{Map<string,
object="">
map =new
HashMap<string, object="">();int
i=10;if(i==10){throw
new
RuntimeException("运行时异常");}return
map;}@AjaxExceptionHandler(tips="试一把",
description="哈啊")@RequestMapping(value="/ajax/net",method=RequestMethod.GET)@ResponseBodypublic
Map<string, object="">
AjaxConnectionExcetion()throws
ConnectException{Map<string,
object="">
map =new
HashMap<string, object="">();int
i=10;if(i==10){throw
new
ConnectException("测试
网络连接 异常");}return
map;}@RequestMapping(value="/ajax/common",method=RequestMethod.GET)@ResponseBodypublic
Map<string, object="">
AjaxExcetion()throws
AjaxException{Map<string,
object="">
map =new
HashMap<string, object="">();int
i=10;if(i==10){throw
new
AjaxException("测试Ajax异常");}return
map;}}</string,></string,></string,></string,></string,></string,></string,></string,></string,>前台页面
123<%@
page language="java"
contentType="text/html;
charset=UTF-8"pageEncoding="UTF-8"%><%@ include file="../../common/meta.jsp"%> <script src="${jqueryCtxPath }/jquery-ui-1.11.2.custom/jquery-ui.min.js"></script>
普通的异常处理测试网络连接异常的Ajax测试
普通异常的Ajax测试<script type="text/javascript"> $(document).ready(function() { $("#test1").click(function(){ $.ajax({ type : 'get', dataType : "json", url : ctx + '/exception/ajax/net', accept:"application/json", success : function(data) { console.log(data);
}, error : function(data, errorThrown) { console.log(data); alert("error" + data.responseText); } }); }); $("#test2").click(function(){ $.ajax({ type : 'get', dataType : "json", url : ctx + '/exception/ajax/common', accept:"application/json", success : function(data)
{ console.log(data); }, error : function(data, errorThrown) { console.log(data); alert("error" + data.responseText); } }); }); }); </script>页面结果演示

springmvc 统一处理异常的更多相关文章
- SpringMVC第六篇【校验、统一处理异常】
Validation 在我们的Struts2中,我们是继承ActionSupport来实现校验的-它有两种方式来实现校验的功能 手写代码 XML配置 这两种方式也是可以特定处理方法或者整个Action ...
- SpringMVC【校验器、统一处理异常、RESTful、拦截器】
前言 本博文主要讲解的知识点如下: 校验器 统一处理异常 RESTful 拦截器 Validation 在我们的Struts2中,我们是继承ActionSupport来实现校验的...它有两种方式来实 ...
- springmvc请求参数异常统一处理,结合钉钉报告信息定位bug位置
参考之前一篇博客:springmvc请求参数异常统一处理 1.ExceptionHandlerController package com.oy.controller; import java.tex ...
- springmvc shiro UnauthorizedException 异常解决方案
springMVC 整合 shiro 时,配置了当访问某个URL没有权限时的配置处理: <!-- 通过unauthorizedUrl指定没有权限操作时跳转页面 --><propert ...
- Java springmvc 统一异常处理的方案
前言:为什么要统一异常处理?经常在项目中需要统一处理异常,将异常封装转给前端.也有时需要在项目中统一处理异常后,记录异常日志,做一下统一处理. Springmvc 异常统一处理的方式有三种. 一.使用 ...
- (转)SpringMVC学习(八)——SpringMVC中的异常处理器
http://blog.csdn.net/yerenyuan_pku/article/details/72511891 SpringMVC在处理请求过程中出现异常信息交由异常处理器进行处理,自定义异常 ...
- SpringMVC实现全局异常处理器 (转)
出处: SpringMVC实现全局异常处理器 我们知道,系统中异常包括:编译时异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手 ...
- 13.SpringMVC之全局异常
我们知道,系统中异常包括:编译时异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手段减少运行时异常的发生.在开发中,不管是dao层 ...
- SpringBoot统一处理异常
在springboot项目,报错有着默认的提示,这篇文章介绍一下如何统一处理异常. 新建项目,pom文件如下: <?xml version="1.0" encoding=&q ...
随机推荐
- javascript开发后端程序的神器nodejs
目录 简介 nodejs的历史 nodejs简介 nodejs的运行环境 process 终止进程 env argv CLI交互 exports模块 nodejs API nodejs的框架 简介 j ...
- requests请求高德地图api
高德地图通过GET方式发送url请求数据.url里需要包含开发者key以及一些请求的具体参数.(详情可见高德官网)高德返回的数据默认为JSON格式,方便处理. 顺带来回忆一下requests模块的一些 ...
- celery使用-win10和linux
win10启动方式 celery -A celery_tasks.main worker -l debug -P eventlet linux启动方式 /usr/local/bin/celery ce ...
- OpenCV-Python图像转换为PyQt图像的变形及花屏无法正常显示问题研究
☞ ░ 前往老猿Python博文目录 ░ 一.引言 在<PyQt转换显示Python-OpenCV图像实现图形化界面的视频播放>介绍了实现在OpenCV和PyQt之间转换并传递图像实现在P ...
- 开源版本Visifire的应用
Visifire曾经开源,保持使用开源版本是不会有版权问题滴. 引用的命名控件 using Visifire.Charts; using Visifire.Commons; 一.应用示例主要代码 // ...
- APP非功能测试
1.移动APP启动时间测试 问题:如何获取启动时间? 答:通过adb的logcat来获取Activity启动时间.用户体验时间=Activity启动时间+启动中异步UI绘制的时间. 启动时间的测试主要 ...
- webpack项目如何正确打包引入的自定义字体
webpack项目如何正确打包引入的自定义字体 一. 如何在Vue或React项目中使用自定义字体 在开发前端项目时,经常会遇到UI同事希望在项目中使用一个炫酷字体的需求.那么怎么在项目中使用自定义字 ...
- 第 5 篇 Scrum 冲刺博客
每天举行会议 会议照片: 昨天已完成的工作与今天计划完成的工作及工作中遇到的困难: 成员姓名 昨天完成工作 今天计划完成的工作 工作中遇到的困难 蔡双浩 实现重设计个人界面的功能添加 实现关注,被关注 ...
- jquery 执行a 标签 点击事件 跳转href 路径
<a href="./export.pdf" id="pdfdown" download="文件名.pdf">下载</a& ...
- memcached session会话共享
1 安装依赖包yum install libevent livevent-devel nc -y 2 yum 安装memcachedyum install -y memcached 3 启动memec ...