springmvc已经实现了异常的处理,这里我对异常进行自定义实现
实现继承SimpleMappingExceptionResolver实现自定义的异常拦截器,
通过viewName是否为空来判断action请求是ajax还是http
import java.io.IOException;
import java.io.PrintWriter;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.SimpleMappingExceptionResolver;
import com.alibaba.druid.support.json.JSONUtils;
public class MySimpleMappingExceptionResolver extends
SimpleMappingExceptionResolver {
@Override
protected ModelAndView doResolveException(HttpServletRequest request,
HttpServletResponse response, Object arg2, Exception ex) {
System.out.println("resolver ...");
String viewName = determineViewName(ex, request);
if (viewName != null) {// JSP格式返回
if (!(request.getHeader("accept").indexOf("application/json") > -1 || (request
.getHeader("X-Requested-With") != null && request
.getHeader("X-Requested-With").indexOf("XMLHttpRequest") > -1))) {
// 如果不是异步请求
// Apply HTTP status code for error views, if specified.
// Only apply it if we're processing a top-level request.
Integer statusCode = determineStatusCode(request, viewName);
if (statusCode != null) {
applyStatusCodeIfPossible(request, response, statusCode);
}
return getModelAndView(viewName, ex, request);
} else {// JSON格式返回
try {
PrintWriter writer = response.getWriter();
Map map=new HashMap();
map.put("success", false);
map.put("msg", ex.getMessage());
writer.write(JSONUtils.toJSONString(map));
writer.flush();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
} else {
return null;
}
}
}
然后在springmvc的配置文件中配置自定义拦截器
<bean id="exceptionResolver"
class="com.dahafo.demo.resolver.MySimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<prop key="java.lang.SQLException">error/sqlerror</prop>
<prop key="java.lang.Exception">error/500</prop>
</props>
</property>
</bean>
最后在srping Controller 中将异常进行抛出
@RequestMapping(value="/query.html",method=RequestMethod.POST)
@ResponseBody
protected Object query(HttpServletRequest request,
HttpServletResponse response) throws Exception {
EtlUser user = new EtlUser();
user.setUserName("test");
if(true)
throw new SQLException("hello error");
return user;
}
分享到:
相关推荐
SSM后台整合(Spring+SpringMvc+Mybtis+事务+Rest风格+统一结果封装+统一异常处理+拦截器) 适合新手练习,熟悉ssm框架 也适合需要进行ssm框架开发的同学,直接无需搭建框架,拿来即用哦
异常统一处理类SysExceptionReslver 用户登录校验过滤器LoginFilter 自定义拦截器SysInterceptor 验证码图片生成CheckCodeServlet 分组校验器ValidGroupSave和ValidGroupUpdate 另外还有IBaseMapper、IBaseService、...
# OnlineExamSystem 基于SSM框架开发的一款在线考试系统 项目简介: 前端框架使用的主要是easyui和jquery 后端框架使用的主要是Spring、SpringMVC、...使用SpringMVC提供的全局异常处理器进行统一异常处理。
主要功能: ... ... 根据课程类型随机抽取数据库中的考试题库并显示试题 在考试过程中会有计时功能,时间到了之后自动交卷 在考生提交试卷后实现自动阅卷功能,并...使用SpringMVC提供的全局异常处理器进行统一异常处理。
● 通过SpringMvc全局异常控制实现系统统一异常处理,其中包括页面信息异常展示与Json异常数据控制; ● 采用Mybatis和二次BaseDao封装完成持久层基本crud操作,提高系统开发效率; ● 通过AOP、自定义注解和...
OnlineExamSystem 基于SSM框架开发的一款在线考试系统 (如果觉得有用的,欢迎Star,感谢~) 功能 ... ... 根据课程类型随机抽取数据库中的考试题库并显示试题 ...使用SpringMVC提供的全局异常处理器进行统一异常处理。
日志管理:通过统一的日志管理器处理功能日志与数据日志关联。提供数据身份标识接口,满足针对表及身份联合查询对照。 日志记录:以JSON格式输出日志,通过log4j配置日志文件输出方式。 日志查询:提供servlet...
后台通过自定义注解结合一个访问拦截器实现整个系统的权限控制 04. 系统前台采用全采用的Html+jQuery开发 05. 系统前台与后台的交互全部使用 Ajax 异步请求 06. 自定义 SecureValid 注解实现权限的控制 07. ...
flylib-boot是针对性的springboot内置的程序的基础框架,专门用于构建程序里的特定统一异常处理 功能 包含一个Spring Boot的一些常见的基础组件的设置 针对Handler的变量的异常处理(处理所有Controller里的Handler...
本课程以通俗易懂的方式讲解SpringMVC核心技术,适合初学者的教程,让你少走弯路!1.SpringMVC简介和实现原理、Controller详解、方法的参数2.数据校验、类型转换、统一异常处理3.拦截器、处理AJAX、文件上传下载
本课程以通俗易懂的方式讲解SpringMVC核心技术,适合初学者的教程,让你少走弯路...1.SpringMVC简介和实现原理、Controller详解、方法的参数2.JSR303数据校验、类型转换、统一异常处理3.拦截器、处理AJAX、文件上传下载
9. 控制器层统一的异常拦截机制,利用@ControllerAdvice统一对异常拦截,具体见com.stylefeng.guns.core.aop.GlobalExceptionHandler类。 10. 页面统一的js key-value单例模式写法,每个页面生成一个唯一的全局变量,...
文档内容 一、 Spring介绍 1 1.1、SpringBoot简介 1 1.2、系统要求: 1 1.3、SpringBoot和SpringMVC区别 1 1.4、SpringBoot和SpringCloud区别 2 ...12.7、SpringBoot整合拦截器 51 12.8、发布打包 52
│ │ │ ├─core----------------项目运行的核心依靠(例如aop日志记录,拦截器,监听器,guns模板引擎,shiro权限检查等) │ │ │ │ │ │ │ ├─modular----------------项目业务代码 │ │ │ │ │ │ │ ├─...