转载: http://blog.csdn.net/m13321169565/article/details/7641978

废话不多,直接说重点。

一  创建异常拦截类

(这里将  webapi 和 web异常放在一起处理。但是文件夹是两个的。关于 LogHelper.WebLog和LogHelper.ApiLog)

参见文章:http://blog.csdn.net/hanjun0612/article/details/72639867

public class AnnotationHandlerMethodExceptionResolver extends ExceptionHandlerExceptionResolver {

    private String defaultErrorView;

    public String getDefaultErrorView() {
return defaultErrorView;
} public void setDefaultErrorView(String defaultErrorView) {
this.defaultErrorView = defaultErrorView;
} /***
* 异常后跳转到页面
*/
protected ModelAndView doResolveHandlerMethodException(HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod, Exception exception) {
try {
if (handlerMethod == null) {
return null;
} Method method = handlerMethod.getMethod(); if (method == null) {
return null;
} ModelAndView returnValue = super.doResolveHandlerMethodException(request, response, handlerMethod, exception); ResponseBody responseBodyAnn = AnnotationUtils.findAnnotation(method, ResponseBody.class);
if (responseBodyAnn != null) { ResponseStatus responseStatusAnn = AnnotationUtils.findAnnotation(method, ResponseStatus.class);
if (responseStatusAnn != null) {
HttpStatus responseStatus = responseStatusAnn.value();
String reason = responseStatusAnn.reason();
if (!StringUtils.hasText(reason)) {
response.setStatus(responseStatus.value());
} else {
response.sendError(responseStatus.value(), reason); }
} return handleResponseBody(returnValue, request, response); } if (returnValue.getViewName() == null) {
returnValue.setViewName(defaultErrorView);
} return returnValue;
} catch (Exception e) {
LogerHelper.WebLog(e.getMessage());
return null;
}
} /**
* 异常后 返回json
*
* @param returnValue
* @param request
* @param response
* @return
* @throws ServletException
* @throws IOException
*/
@SuppressWarnings({"unchecked", "rawtypes"})
private ModelAndView handleResponseBody(ModelAndView returnValue, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
Map value = returnValue.getModelMap();
HttpInputMessage inputMessage = new ServletServerHttpRequest(request);
List<MediaType> acceptedMediaTypes = inputMessage.getHeaders().getAccept();
if (acceptedMediaTypes.isEmpty()) {
acceptedMediaTypes = Collections.singletonList(MediaType.ALL);
}
MediaType.sortByQualityValue(acceptedMediaTypes);
HttpOutputMessage outputMessage = new ServletServerHttpResponse(response);
Class<?> returnValueType = value.getClass();
List<HttpMessageConverter<?>> messageConverters = super.getMessageConverters();
if (messageConverters != null) {
for (MediaType acceptedMediaType : acceptedMediaTypes) {
for (HttpMessageConverter messageConverter : messageConverters) {
if (messageConverter.canWrite(returnValueType, acceptedMediaType)) {
messageConverter.write(value, acceptedMediaType, outputMessage);
return new ModelAndView();
}
}
}
}
if (logger.isWarnEnabled()) {
logger.warn("Could not find HttpMessageConverter that supports return type [" + returnValueType + "] and " + acceptedMediaTypes);
}
return null;
} catch (Exception e) {
LogerHelper.ApiLog(e.getMessage());
return null;
}
} }

二 添加xml配置

找到springmvc-servlet.xml

添加:

<bean id="handlerExceptionResolver" class="com.sanju.sanjuSCM.ExceptionResolver.AnnotationHandlerMethodExceptionResolver">
<property name="defaultErrorView" value="error/500.jsp"/> <!--错误页面-->
<property name="messageConverters">
<list>
<bean class="org.springframework.http.converter.ByteArrayHttpMessageConverter" />
<!-- JSON转换器无需设置mediaType,由外部客户端调用时,手动设置相关mediaType -->
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter" />
</list>
</property>
</bean>

就完成了!

====================================================================================

下面是我项目中用到的。
配置文件和上面的还是一样

public class AnnotationHandlerMethodExceptionResolver extends ExceptionHandlerExceptionResolver {

    private String defaultErrorView;

    public String getDefaultErrorView() {
        return defaultErrorView;
    }     public void setDefaultErrorView(String defaultErrorView) {
        this.defaultErrorView = defaultErrorView;
    }     /***
     * 异常后跳转到页面
     */
    protected ModelAndView doResolveHandlerMethodException(HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod, Exception exception) {         Method method=null;
        ModelAndView returnValue=null;
        try {
            if (handlerMethod == null) {
                return null;
            }             method = handlerMethod.getMethod();             if (method == null) {
                return null;
            }             returnValue = super.doResolveHandlerMethodException(request, response, handlerMethod, exception); //这里获取 @RestController和普通 @ResponseBody 的两种注解情况
            Annotation restControllerAnn = method.getDeclaringClass().getAnnotation(RestController.class);
            Annotation responseBodyAnn = restControllerAnn==null
                            ?AnnotationUtils.findAnnotation(method, ResponseBody.class)
                            :restControllerAnn;
            if (responseBodyAnn != null) {                 ResponseStatus responseStatusAnn = AnnotationUtils.findAnnotation(method, ResponseStatus.class);
                if (responseStatusAnn != null) {
                    HttpStatus responseStatus = responseStatusAnn.value();
                    String reason = responseStatusAnn.reason();
                    if (!StringUtils.hasText(reason)) {
                        response.setStatus(responseStatus.value());
                    } else {
                        response.sendError(responseStatus.value(), reason);                     }
                }                 return handleResponseBody(returnValue, request, response,handlerMethod,exception);             }             if (returnValue.getViewName() == null) {
                returnValue.setViewName(defaultErrorView);
            }             return returnValue;
        } catch (Exception e) {
            SimpleDateFormat formatter =new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss"); ;             String exMsg="\r\n\r\n============================================================\r\n";
            exMsg+="Date : "+(formatter.format(new Date()))+"\r\n\n";
            exMsg+="ErrorMsg : "+exception+"\r\n\n";
            exMsg+="ClassName : "+handlerMethod.getBean().getClass()+"\r\n\n";
            exMsg+="MethodName : "+handlerMethod.getMethod().getName()+"\r\n\n";
            exMsg+="Exception : "+handlerMethod +"\r\n\n";
            LogerHelper.WebLog(exMsg);
            return null;
        }
    }     /**
     * 异常后 返回json
     *
     * @param returnValue
     * @param request
     * @param response
     * @return
     * @throws ServletException
     * @throws IOException
     */
    @SuppressWarnings({"unchecked", "rawtypes"})
    private ModelAndView handleResponseBody(ModelAndView returnValue, HttpServletRequest request, HttpServletResponse response, HandlerMethod handlerMethod, Exception exception) throws Exception {
        ResultModel rm=new ResultModel();
        rm.setMessage(exception.getMessage());
        try {
            String json= JsonConvert.toJSON(rm);
            response.getWriter().write(json);
            response.getWriter().flush();
            response.getWriter().close();
            return null;
        } catch (Exception e) {             SimpleDateFormat formatter =new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss"); ;             String exMsg="\r\n\r\n============================================================\r\n";
            exMsg+="Date : "+(formatter.format(new Date()))+"\r\n\n";
            exMsg+="reqString : "+request.getParameter("reqString")+"\r\n";
            exMsg+="sign : "+request.getParameter("sign") +"\r\n";
            exMsg+="ErrorMsg : "+exception+"\r\n\n";
            exMsg+="ClassName : "+handlerMethod.getBean().getClass()+"\r\n\n";
            exMsg+="MethodName : "+handlerMethod.getMethod().getName()+"\r\n\n";
            exMsg+="Exception : "+handlerMethod +"\r\n\n";             LogerHelper.ApiLog(exMsg);
            rm.setMessage(e.getMessage());
            String json= JsonConvert.toJSON(rm);
            response.getWriter().write(json);
            response.getWriter().flush();
            response.getWriter().close();
        }
return  null;
    } }  

SSM 全局异常的更多相关文章

  1. SSM之全局异常处理器

    1. 异常处理思路 首先来看一下在springmvc中,异常处理的思路:   如上图所示,系统的dao.service.controller出现异常都通过throws Exception向上抛出,最后 ...

  2. 使用spring利用HandlerExceptionResolver实现全局异常捕获

    最近一直没有时间更新是因为一直在更新自己使用的框架. 之后会慢慢带来对之前使用的spring+mvc+mybatis的优化. 会使用一些新的特性,实现一些新的功能. 我会尽量分离业务,封装好再拿出来. ...

  3. springmvc 全局异常解决方案

    系统中异常包括两类:预期异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手段减少运行时异常的发生. 系统的dao.service. ...

  4. SpringBoot学习笔记(二):SpringBoot访问静态文件、捕获全局异常、集成Thymeleaf、集成JSP

    SpringBoot访问静态文件 什么是静态文件? 不需要通过web容器去得到的文件,直接通过路径就能得到的文件,比如项目的css,js,img等文件. 所有的资源文件都应该在src/main/res ...

  5. 13.SpringMVC之全局异常

    我们知道,系统中异常包括:编译时异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手段减少运行时异常的发生.在开发中,不管是dao层 ...

  6. 在C#代码中应用Log4Net(四)在Winform和Web中捕获全局异常

    毕竟人不是神,谁写的程序都会有bug,有了bug不可怕,可怕的是出错了,你却不知道错误在哪里.所以我们需要将应用程序中抛出的所有异常都记录起来,不然出了错,找问题就能要了你的命.下面我们主要讨论的是如 ...

  7. MVC 好记星不如烂笔头之 ---> 全局异常捕获以及ACTION捕获

    public class BaseController : Controller { /// <summary> /// Called after the action method is ...

  8. spring设置全局异常处理器

    1.spring设置全局异常,它的原理是向上捕获 spring.xml配置 <!--自定义全局异常处理器--> <bean id="globalExceptionResol ...

  9. atitit.js浏览器环境下的全局异常捕获

    atitit.js浏览器环境下的全局异常捕获 window.onerror = function(errorMessage, scriptURI, lineNumber) { var s= JSON. ...

随机推荐

  1. centos 7 163 yum 源 python 2.7.5

    安装 repo 源. repo 源一般包括 base, updates, Extras 三部分. $ cd /etc/yum.repos.d/ $ wget http://mirrors.163.co ...

  2. 降阶法计算行列式方法有个地方有Bug(原文也已更正,此为更正后部分)

    今天用此函数做方程求解时发现有误,特此更正: /// <summary> /// 降阶法计算行列式 /// </summary> /// <param name=&quo ...

  3. 20155328 网络攻防 实验五:MSF基础应用

    20155328 网络攻防 实验五:MSF基础应用 实践内容及过程记录 一.Windows服务渗透攻击----ms08_067 攻击机:kali 靶机:WindowsXP(英文版) 第一步,分别查看攻 ...

  4. 【Win32 API】利用SendMessage实现winform与wpf之间的消息传递

    原文:[Win32 API]利用SendMessage实现winform与wpf之间的消息传递 引言    有一次心血来潮,突然想研究一下进程间的通信,能够实现消息传递的方法有几种,其中win32ap ...

  5. 【WPF】两则动画效果

    原文:[WPF]两则动画效果 引言 利用WPF的动画可以轻而易举的实现各种各样的特效,如擦除,滑动进入等,先看两个效果图 第一个效果 这个动画其实利用了OpacityMask和LinearGradie ...

  6. [Oracle]System 表空间的文件丢失

    如果system 表空间的文件丢失,假设有备份的情况,可以恢复.数据库需要设置为mount 状态,然后restore/recover datafile 模拟实验: SQL> select nam ...

  7. [清华集训2015 Day1]玛里苟斯-[线性基]

    Description Solution 考虑k=1的情况.假设所有数中,第i位为1的数的个数为x,则最后所有的子集异或结果中,第i位为1的个数为$(C_{k}^{1}+C_{k}^{3}+...)$ ...

  8. stl源码剖析 详细学习笔记 配接器

    //---------------------------15/04/03---------------------------- /* 配接器概述: 1:adapter是一种设计模式:将一个clas ...

  9. Android 实现 WheelView

    wheel view 目录(?)[-] Android WheelView效果图 网上的开源代码 实现思路 扩展Gallery 如何使用 我们都知道,在iOS里面有一种控件------滚筒控件(Whe ...

  10. 【Direct2D1.1初探】Direct2D特效概览

    转载请注明出处:http://www.cnblogs.com/Ray1024 一.概述 Direct2D是一个基于Direct3D的2D图形API,可以利用硬件加速特性来提供高性能高质量的2D渲染.但 ...