
SSM学习第三天
SpringMvc中的拦截器和异常处理
一、SpringJdbcTemplate基本使用
1.1 、JdbcTemplate概述
它是spring框架中提供的一个对象,是对原始繁琐的Jdbc API对象的简单封装。spring框架为我们提供了很多的操作模板类。例如:操作关系型数据的JdbcTemplate和HibernateTemplate,操作nosql数据库的RedisTemplate,操作消息队列的JmsTemplate等等。
1.2 、JdbcTemplate开发步骤
①导入spring-jdbc和spring-tx坐标
1 | <!--导入spring的jdbc坐标--> |
②创建数据库表和实体
③创建JdbcTemplate对象
④执行数据库操作
1 | //1、创建数据源对象 |
我们可以将JdbcTemplate的创建权交给Spring,将数据源DataSource的创建权也交给Spring,在Spring容器内部将数据源DataSource注入到JdbcTemplate模版对象中,配置如下:
使用配置文件:
1 | jdbc.driver=com.mysql.jdbc.Driver |
1 | <!--1、加载jdbc.properties--> |
1 |
|
1.3、JdbcTemplate的常用操作
修改操作
1
2
3
4
5
6
7
8
9
10
11
public class JdbcTemplateCRUDTest {
private JdbcTemplate jdbcTemplate;
//测试修改操作
public void testUpdate(){
jdbcTemplate.update("update account set money=? where name=?",1000,"tom");
}
}删除和查询全部操作
1
2
3
4
5
6
7
8
9
10
11
public void testDelete(){
jdbcTemplate.update("delete from account where name=?","tom");
}
public void testQueryAll(){
List<Account> accounts = jdbcTemplate.query("select * from account", new BeanPropertyRowMapper<Account>(Account.class));
for (Account account : accounts) {
System.out.println(account.getName());
}
}查询单个数据操作操作
1
2
3
4
5
6
7
8
9
10
11
12
//测试查询单个对象操作
public void testQueryOne(){
Account account = jdbcTemplate.queryForObject("select * from account where name=?", new BeanPropertyRowMapper<Account>(Account.class), "tom");
System.out.println(account.getName());
}
//测试查询单个简单数据操作(聚合查询)
public void testQueryCount(){
Long aLong = jdbcTemplate.queryForObject("select count(*) from account", Long.class);
System.out.println(aLong);
}
二、SpringMVC拦截器
1.1 、拦截器(interceptor)的作用
Spring MVC 的拦截器类似于 Servlet 开发中的过滤器 Filter,用于对处理器进行预处理和后处理。
将拦截器按一定的顺序联结成一条链,这条链称为拦截器链(Interceptor Chain)。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用。拦截器也是AOP思想的具体实现
1.2 、拦截器和过滤器区别
区别 | 过滤器 | 拦截器 |
---|---|---|
使用范围 | 是 servlet 规范中的一部分,任何 Java Web 工程都可以使用 | 是 SpringMVC 框架自己的,只有使用了 SpringMVC 框架的工程才能用 |
拦截范围 | 在 url-pattern 中配置了/*之后,可以对所有要访问的资源拦截 | 只会拦截访问的控制器方法,如果访问的是 jsp,html,css,image 或者 js 是不会进行拦截的 |
1.3 、拦截器是快速入门
自定义拦截器很简单,只有如下三步:
①创建拦截器类实现HandlerInterceptor接口
方法名 | 说明 |
---|---|
preHandle() | 方法将在请求处理之前进行调用,该方法的返回值是布尔值Boolean类型的,当它返回为false 时,表示请求结束,后续的Interceptor 和Controller 都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的preHandle 方法 |
postHandle() | 该方法是在当前请求进行处理之后被调用,前提是preHandle 方法的返回值为true 时才能被调用,且它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作 |
afterCompletion() | 该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行,前提是preHandle 方法的返回值为true 时才能被调用 |
1 | public class MyHandlerInterceptor1 implements HandlerInterceptor { |
②配置拦截器
1 | <!--配置拦截器--> |
③测试拦截器的拦截效果
1 |
|
结果:
如果有多个拦截器,则遵循先配先进,先进后出
三、SpringMVC异常处理
1.1 异常处理的思路
系统中异常包括两类:预期异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发、测试等手段减少运行时异常的发生。
系统的Dao、Service、Controller出现都通过throws Exception向上抛出,最后由SpringMVC前端控制器交由异常处理器进行异常处理,如下图:
1.2 异常处理两种方式
使用Spring MVC提供的简单异常处理器SimpleMappingExceptionResolver
实现Spring的异常处理接口HandlerExceptionResolver 自定义自己的异常处理器
1.3 简单异常处理器SimpleMappingExceptionResolver
SpringMVC已经定义好了该类型转换器,在使用时可以根据项目情况进行相应异常与视图的映射配置
1.4 自定义异常处理步骤
①创建异常处理器类实现HandlerExceptionResolver
1 | public class MyExceptionResolver implements HandlerExceptionResolver { |
②配置异常处理器
③编写异常页面
④测试异常跳转
1 |
|