SpringBoot---day06--异常处理和单元测试

一:SpringBoot中异常处理方式

1.SpringBoot对于异常处理提供了五种方式

1.1自定义错误页面

SpringBoot默认处理异常的机制:SpringBoot默认的已经提供了一套处理异常的机制,一旦程序中出现了异常SpringBoot会向/error的URL发送请求。在SpringBoot提供了叫BasicExceptionController来处理请求。然后跳转到默认显示异常的页面来展示异常信息。

如果我们需要将所有的异常统一跳转到自定义的错误页面,需要src/main/resource/tempates目录下创建error.html页面。注意:名称必须叫error.html

1.2@ExceptionHandle注解处理异常

Controller层代码

package com.springboot.controller;

/**
 * SpringBoot处理异常方式一:自定义错误页面
 * @author Administrator
 *
 */
import org.springframework.web.servlet.ModelAndView;
@Controller
public class DemoController {

	@RequestMapping("/show")
	public String showInfo(Model model) {
		String str = null;
		str.length();
		return "index";
	}
	@RequestMapping("/show2")
	public String showInfo2(Model model) {
		int i=10/0;
		return "index";
	}
	/**
	 *  java.lang.ArithmeticException
	 *  该方法需要返回一个ModelAndView:目的是可以让我们封装异常信息以及视图的指定。
	 *  Exception exception:会将产生的异常注入到方法中。
	 * @return
	 */
	@ExceptionHandler(value= {java.lang.ArithmeticException.class})
	public ModelAndView arithmeticExceptionHandler(Exception ex) {
		ModelAndView mv = new ModelAndView();
		mv.addObject("error",ex.toString());
		mv.setViewName("error1");
		return mv;
	}
	/**
	 *  java.lang.ArithmeticException
	 *  该方法需要返回一个ModelAndView:目的是可以让我们封装异常信息以及视图的指定。
	 *  Exception exception:会将产生的异常注入到方法中。
	 * @return
	 */
	@ExceptionHandler(value= {	java.lang.NullPointerException.class})
	public ModelAndView nullPointerExceptionHandler(Exception ex) {
		ModelAndView mv = new ModelAndView();
		mv.addObject("error",ex.toString());
		mv.setViewName("error2");
		return mv;
	}
}

页面error1 和error2

error1.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>错误提示信息--ArithmeticException</title>
</head>
<body>
	出错了!请与管理员联系。
	<span th:text="${error}"></span>
</body>
</html>
error2.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>错误提示信息--	NullPointerException</title>
</head>
<body>
	出错了!请与管理员联系。
	<span th:text="${error}"></span>
</body>
</html> 


1.3@ControllerAdvice+@ExceptionHandle注解处理异常

需要创建一个能够处理异常的全局异常类。在该类上需要添加@ControllerAdvice注解

@ControllerAdvice
public class GlobalException {
	/**
	 *  java.lang.ArithmeticException
	 *  该方法需要返回一个ModelAndView:目的是可以让我们封装异常信息以及视图的指定。
	 *  Exception exception:会将产生的异常注入到方法中。
	 * @return
	 */
	@ExceptionHandler(value= {java.lang.ArithmeticException.class})
	public ModelAndView arithmeticExceptionHandler(Exception ex) {
		ModelAndView mv = new ModelAndView();
		mv.addObject("error",ex.toString());
		mv.setViewName("error1");
		return mv;
	}
	/**
	 *  java.lang.ArithmeticException
	 *  该方法需要返回一个ModelAndView:目的是可以让我们封装异常信息以及视图的指定。
	 *  Exception exception:会将产生的异常注入到方法中。
	 * @return
	 */
	@ExceptionHandler(value= {java.lang.NullPointerException.class})
	public ModelAndView nullPointerExceptionHandler(Exception ex) {
		ModelAndView mv = new ModelAndView();
		mv.addObject("error",ex.toString());
		mv.setViewName("error2");
		return mv;
	}
}

1.4配置SimpleMappingExceptionResolver类完成异常处理
1.4.1在全局异常类中添加一个方法完成异常的统一处理

@Configuration
public class GlobalException {
	/**
	 * 该方法必须要有返回值。返回值类型必须是:SimpleMappingExceptionResolver
	 */
	@Bean
	public SimpleMappingExceptionResolver getSimpleMappingExceptionResolver() {
		SimpleMappingExceptionResolver resolver = new SimpleMappingExceptionResolver();
		Properties mappings = new Properties();
		/**
		 * 参数一:异常的类型,注意必须是异常类型的全名
		 * 参数二:视图名称
		 */
		mappings.put("java.lang.ArithmeticException", "error1");
		mappings.put("java.lang.NullPointerException", "error2");
		//设置异常与视图映射的异常信息
		resolver.setExceptionMappings(mappings);
		return resolver;
	}
	
}

1.5自定义HandleExceptionResolver类处理异常

需要在全局处理异常类中实现HandleExceptionResolver接口

@Configuration
public class GlobalException implements HandlerExceptionResolver {

	@Override
	public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler,
			Exception ex) {
		ModelAndView mv = new ModelAndView();
		// 判断不同异常类型,做不同的视图跳转
		if (ex instanceof ArithmeticException) {
			mv.setViewName("error1");
		}

		if (ex instanceof NullPointerException) {
			mv.setViewName("error2");
		}
		mv.addObject("error",ex.toString());
		return mv;
	}

}

二:SpringBoot整合Junit单元测试

1.修改pom文件

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.5.10.RELEASE</version>
	</parent>
	<groupId>com.springboot</groupId>
	<artifactId>19-springboot-test</artifactId>
	<version>0.0.1-SNAPSHOT</version>

	<properties>
		<java.version>1.7</java.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<!-- 添加junit环境的jar包  -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
		</dependency>
	</dependencies>

</project>

2.编写业务代码 dao层+Service层

@Repository
public class UserDaoImpl {
	
	public void saveUser() {
		System.out.println("insert into Users...");
	}
}


@Service
public class UserServiceImpl {
	
	@Autowired
	private UserDaoImpl userDaoImpl;

	public void saveUser() {
		userDaoImpl.saveUser();
	}
	
}

3.使用SpringBoot整合Junit做单元测试

3.1编写测试类

/**
 * SpringBoot测试类
 * @RunWith:启动器
 * @SpringBootTest(classes= {App.class}):1.当前类是SpringBoot的测试类  2.加载SpringBoot启动类,启动SpringBoot
 * SpringJUnit4ClassRunner.class:让Junit与Spring环境进行整合。
 * @author Administrator
 * 
 * Junit与Spring整合的时候 要加上 @Contextconfiguration(classpath:applicationContext.xml)
 *
 */
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes= {App.class})
public class UserServiceTest {

	@Autowired
	private UserServiceImpl userServiceImpl;
	@Test
	public void testAddUser() {
		userServiceImpl.saveUser();
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值