Spring MVC 的异常处理

1 普通的异常处理方式有什么不足
普通的异常处理方式可以是try … catch … finally,或者throw + throws。

在一个项目中,可能有些异常出现的频率高较,而频繁的在代码中使用以上处理异常的语法可能比较繁琐。

2 使用SimpleMappingExceptionResolver
通过使用SimpleMappingExceptionResolver,可以配置异常与某些页面的映射关系,配置完成后,无论是处理哪个请求时出现了指定的异常,都会直接到指定的页面!

SimpleMappingExceptionResolver是Spring MVC中已经存在的类,我们需要做的就是在Spring MVC的配置文件中通过节点配置它,并且在其中配置异常与页面的映射关系即可,例如:

error1 error2 这种做法比较简单,但是处理得相对比较粗糙,提示的信息不够精准!

3 使用@ExceptionHandler
在Controller中,可以自定义方法,使用@ExceptionHandler进行注解,一旦处理请求过程中出现异常,Spring MVC就会自动调用该方法。

自定义的方法和平时使用的处理请求的方法一样,方法名称可以自定义,参数可以根据需要自行添加,通常,至少添加Exception作为参数,以判断异常的类型。

@ExceptionHandler
public String handleException(HttpServletRequest request,
Exception ex) {
request.setAttribute(“errorMessage”, ex.getMessage());

if (ex instanceof NullPointerException) {
    return "error3";
} else if (ex instanceof ArrayIndexOutOfBoundsException) {
    return "error4";
} else {
    return "error5";
}

}
这种做法也很简单,由于是在程序中进行处理,所以,自由度更高!

这种做法与使用SimpleMappingExceptionResolver是冲突的,在使用这种做法之前,先确保没有使用SimpleMappingExceptionResolver,不要同时使用这2种方式处理相同的异常。

在使用这种做法时,如果需要多个Controller都应用这种处理异常的方式,可以把以上代码写一个父类中,然后每个Controller都继承自这个类!

public abstract class ExceptionController {

@ExceptionHandler
public String handleException() { .... }

}

public class MainController extends ExceptionController {
// 这个类用于处理各种请求
}
MyBatis
1 基本概念
MyBatis是在项目中用于解决数据存储的框架,即访问数据库的框架。

使用了MyBatis后,在访问数据库时,只需要定义接口,并配置接口中的抽象方法对应的SQL语句即可,而不需要开发接口的实现类!

2 基本使用
2.1 添加依赖
创建新项目:10-MyBatis-01-Sample,执行常规操作,并添加以下依赖:

Group ID Artifact Version
org.springframework spring-webmvc 3.2.8.RELEASE
commons-dbcp commons-dbcp 1.4
mysql mysql-connector-java 5.1.37
junit junit 4.12
org.springframework spring-jdbc 3.2.8.RELEASE
mybatis mybatis 3.2.8
org.mybatis mybatis-spring 1.3.1
操作完成后,检查在src\main\resources下是否存在数据库连接池的.properties配置文件、文件内是否正确配置,检查Spring的配置文件中是否加载了这个配置、是否配置了BasicDataSource。

2.2 设定目标
向tedu_ums数据库的t_user数据表中添加1条用户数据,数据中包括username、password、phone、email。

2.3 【开发】创建持久层Java代码
创建cn.tedu.ssm.bean.User实体类,声明id和以上4个属性。

创建cn.tedu.ssm.mapper.UserMapper接口,在接口中声明:

void createUser(User user);
2.4 【开发】创建持久层的映射
先从FTP服务器下载mapper.zip并解压缩。

在src\main\resources中新建mappers文件夹,然后粘贴解压缩得到的文件,并重命名为UserMapper.xml。

在UserMapper.xml的根节点中,添加namespace属性,值为匹配的Java接口文件的全名:

然后,在中添加子级节点,以对应Java接口中的抽象方法,如果该方法执行的是增加数据操作,则添加节点,同理,如果执行的是删除操作,则添加节点,以此类推。此次显然使用节点,必须配置的属性是id,值为抽象方法的名称,即:
<!-- 通过子节点配置与抽象方法的映射关系 -->
<insert id="createUser">
</insert>
由于对应的方法是有参数的,则在节点上配置parameterType属性以确定参数的类型,取值为该类型的全名。

然后,在节点内部,编写此次操作需要执行的SQL语句,在SQL语句中,变量使用#{}表达式,如果SQL语句中变量是方法的参数的某个属性,可以直接写属性名,例如:

<!-- 通过子节点配置与抽象方法的映射关系 -->
<insert id="createUser" 
    parameterType="cn.tedu.ssm.bean.User">
    INSERT INTO t_user (
        username, password, 
        phone, email
    ) VALUES (
        #{username}, #{password}, 
        #{phone}, #{email}
    )
</insert>
2.5 【开发】配置MyBatis 在Spring的配置文件中,配置: 2.6 【开发】获取新增加的数据的ID 如果需要获取新记录的ID,则在节点中需要添加2个属性:useGeneratedKeys="true"和keyProperty="id",例如:


当添加这些配置以后,在MyBatis执行增加操作后,会把新记录的ID封装到用于增加操作的对象中,即:如果调用createUser()方法时,使用的User userA对象作为参数,则执行完后,userA中就有了新记录的ID:

userMapper.createUser(user);
Integer id = user.getId();
2.7 小结:如何使用Spring整合后的MyBatis

  1. 添加依赖,依赖的jar包的版本不限,但可以统一版本号的请尽量统一,特别是以spring-作为前缀的!

  2. 配置spring-mvc.xml,在这个文件中,至少要配置:组件扫描、ViewResolver、读取db.properties、配置dbcp(BasicDataSource)、配置MapperScannerConfigurer、配置SqlSessionFactoryBean,如果这些配置是从其它的项目中复制过来的,请检查值是否需要修改!

  3. 编写接口文件,并定义抽象方法,如果需要相关实体类,则创建所需的实体类

  4. 配置对应的映射:Mapper.xml文件可以从FTP下载,或从此前的项目中复制,通常推荐将这个文件存放在src\main\resources\mappers下(请与Spring配置中保持一致),然后编辑文件的内容

3 练习:查询特定的某条数据
3.1 设定目标
在以上基础之上,添加根据用户名查询数据的功能。

3.2 【开发】持久层–接口
在UserMapper.java接口中添加新的抽象方法:

User findUserByUsername(String username);
3.3 【开发】持久层–映射
在UserMapper.xml映射文件中添加子节点:


SELECT
id, username, password, phone, email
FROM
t_user
WHERE
username=#{username}

在配置这些节点时,如果接口中声明的方法只有1个参数,并且是基本数据类型或String类型,可以不需要通过parameterType指定参数的数据类型。

由于此次操作是需要返回值的,则需要在节点添加resultType属性指定返回值的数据类型。

3.4 【测试】
在测试类中进行测试。

4 练习:查询多条数据
4.1 设定目标
查询所有用户数据,不指定查询条件

4.2 【开发】持久层–接口
在UserMapper.java接口中添加新的抽象方法:

List findAllUser();
4.3 【开发】持久层–映射
在UserMapper.xml映射文件中添加子节点:


SELECT
id, username, password, phone, email
FROM
t_user

4.4 【测试】
在测试类中进行测试。

5 练习:删除数据
5.1 设定目标
根据ID删除数据

5.2 【开发】持久层–接口
在UserMapper.java接口中添加新的抽象方法:

Integer delete(Integer id);
5.3 【开发】持久层–映射
在UserMapper.xml映射文件中添加子节点:

DELETE FROM t_user WHERE id=#{id} 5.4 【测试】 在测试类中进行测试。

6 练习:修改数据
6.1 设定目标
根据id修改密码、手机号码、电子邮件,不允许修改用户名。

6.2 【开发】持久层–接口
在UserMapper.java接口中添加新的抽象方法:

Integer updateUserInfo(User user);
6.3 【开发】持久层–映射
在UserMapper.xml映射文件中添加子节点:


UPDATE
t_user
SET
password=#{password},phone=#{phone},email=#{email}
WHERE
id=#{id}

6.4 【测试】
在测试类中进行测试。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值