diff --git a/README.md b/README.md index 16da43f..30e3a09 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ # Spring Boot Demo -spring boot demo 是一个用来学习 spring boot 的项目,已经集成 actuator(监控)、admin(可视化监控)、logback(日志)、aopLog(通过 AOP 记录 web 请求日志)、JPA(ORM 框架)、mybatis(ORM 框架)、redis-cache(缓存)、swagger(API 接口管理测试)、ureport2(中国式报表)模块,后续会集成activemq,email, freemarker,shiro,websocket,quartz,netty等模块。 +spring boot demo 是一个用来学习 spring boot 的项目,已经集成 actuator(监控)、admin(可视化监控)、logback(日志)、aopLog(通过 AOP 记录 web 请求日志)、统一异常处理( json 级别和页面级别)、JPA(ORM 框架)、mybatis(ORM 框架)、redis-cache(缓存)、swagger(API 接口管理测试)、ureport2(中国式报表)模块,后续会集成activemq,email, freemarker,shiro,websocket,quartz,netty等模块。 依赖的 Spring Boot 版本: @@ -51,6 +51,7 @@ spring boot demo 是一个用来学习 spring boot 的项目,已经集成 actu ../spring-boot-demo-admin ../spring-boot-demo-logback ../spring-boot-demo-aoplog + ../spring-boot-demo-exceptionhandler ../spring-boot-demo-orm-jpa ../spring-boot-demo-orm-mybatis ../spring-boot-demo-cache-redis @@ -148,6 +149,7 @@ spring boot demo 是一个用来学习 spring boot 的项目,已经集成 actu | [spring-boot-demo-admin](./spring-boot-demo-admin) | spring-boot 集成 spring-boot-admin 来可视化的监控 spring-boot 程序的运行状态,可以与 actuator 互相搭配使用 | | [spring-boot-demo-logback](./spring-boot-demo-logback) | spring-boot 集成 logback 日志 | | [spring-boot-demo-aoplog](./spring-boot-demo-aoplog) | spring-boot 使用 AOP 切面的方式记录 web 请求日志 | +| [spring-boot-demo-exceptionhandler](./spring-boot-demo-exceptionhandler) | spring-boot 统一异常处理,包括2种,一种返回统一的 json 格式,第二种统一跳转到异常页面 | | [spring-boot-demo-orm-jpa](./spring-boot-demo-orm-jpa) | spring-boot 集成 spring-boot-starter-data-jpa 操作数据库 | | [spring-boot-demo-orm-mybatis](./spring-boot-demo-orm-mybatis) | spring-boot 集成 [mybatis-spring-boot-starter](https://github.com/mybatis/spring-boot-starter)、[mybatis-spring-boot-starter](https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter) | | [spring-boot-demo-cache-redis](./spring-boot-demo-cache-redis) | spring-boot 使用 Redis 做缓存 | diff --git a/TODO.md b/TODO.md index 7d23c79..9d5aac4 100644 --- a/TODO.md +++ b/TODO.md @@ -1,14 +1,14 @@ # spring-boot-demo 项目 -## 模块计划 +## 模块计划(已完成:12 / 35) - [x] ~~spring-boot-demo-helloworld(Helloworld 示例)~~ - [x] ~~spring-boot-demo-properties(读取配置文件信息)~~ - [x] ~~spring-boot-demo-actuator(对 Spring boot 的端点监控)~~ - [x] ~~spring-boot-demo-admin(对 Spring boot 可视化管控)~~ - [x] ~~spring-boot-demo-logback(集成 logback 日志)~~ -- [x] spring-boot-demo-aoplog(使用 AOP 拦截请求日志信息) -- [ ] spring-boot-demo-exceptionHandler(统一异常处理) +- [x] ~~spring-boot-demo-aoplog(使用 AOP 拦截请求日志信息)~~ +- [x] ~~spring-boot-demo-exceptionhandler(统一异常处理)~~ - [ ] spring-boot-demo-orm-jdbcTemplate(操作 SQL 关系型数据库 - JdbcTemplate) - [x] ~~spring-boot-demo-orm-jpa(操作 SQL 关系型数据库 - JPA)~~ - [x] ~~spring-boot-demo-orm-mybatis(操作 SQL 关系型数据库 - mybatis)~~ diff --git a/spring-boot-demo-aoplog/README.md b/spring-boot-demo-aoplog/README.md index 42af1b0..7719b8c 100644 --- a/spring-boot-demo-aoplog/README.md +++ b/spring-boot-demo-aoplog/README.md @@ -12,7 +12,7 @@ spring-boot-demo-aoplog 0.0.1-SNAPSHOT - jar + war spring-boot-demo-aoplog Demo project for Spring Boot diff --git a/spring-boot-demo-aoplog/pom.xml b/spring-boot-demo-aoplog/pom.xml index cc363f9..b01dfc8 100644 --- a/spring-boot-demo-aoplog/pom.xml +++ b/spring-boot-demo-aoplog/pom.xml @@ -5,7 +5,7 @@ spring-boot-demo-aoplog 0.0.1-SNAPSHOT - jar + war spring-boot-demo-aoplog Demo project for Spring Boot diff --git a/spring-boot-demo-exceptionhandler/README.md b/spring-boot-demo-exceptionhandler/README.md new file mode 100644 index 0000000..986aa32 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/README.md @@ -0,0 +1,180 @@ +# spring-boot-demo-exceptionhandler + +依赖[spring-boot-demo-parent](../spring-boot-demo-parent)、`spring-boot-starter-thymeleaf`(关于 thymeleaf 的会在后面的模板引擎专门有demo) + +### pom.xml + +```xml + + + 4.0.0 + + spring-boot-demo-exceptionhandler + 0.0.1-SNAPSHOT + war + + spring-boot-demo-exceptionhandler + Demo project for Spring Boot + + + com.xkcoding + spring-boot-demo-parent + 0.0.1-SNAPSHOT + ../spring-boot-demo-parent/pom.xml + + + + + org.springframework.boot + spring-boot-starter-thymeleaf + + + + + spring-boot-demo-exceptionhandler + + + +``` + +### application.yml + +```yaml +server: + port: 8080 + context-path: /demo +spring: + thymeleaf: + mode: HTML5 + encoding: UTF-8 + content-type: text/html + cache: false +``` + +### DemoExceptionHandler.java + +```java +/** + * 自定义异常统一处理 + * + * @package: com.xkcoding.springbootdemoexceptionhandler.handler + * @description: 自定义异常统一处理 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:37 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@ControllerAdvice +@Slf4j +public class DemoExceptionHandler { + public static final String DEFAULT_ERROR_VIEW = "error"; + + /** + * 统一 json 异常处理 + * + * @param exception DemoJsonException + * @return 统一返回 json 格式 + */ + @ExceptionHandler(value = DemoJsonException.class) + @ResponseBody + public R jsonErrorHandler(DemoJsonException exception) { + log.error("【DemoJsonException】:{}", exception.getMessage()); + return R.error(exception); + } + + /** + * 统一 页面 异常处理 + * + * @param exception DemoPageException + * @return 统一跳转到异常页面 + */ + @ExceptionHandler(value = DemoPageException.class) + public ModelAndView pageErrorHandler(DemoPageException exception) { + log.error("【DemoPageException】:{}", exception.getMessage()); + ModelAndView view = new ModelAndView(); + view.addObject("message", exception.getMessage()); + view.setViewName(DEFAULT_ERROR_VIEW); + return view; + } +} +``` + +### R.java + +```java +/** + * 统一返回的 json 对象 + * + * @package: com.xkcoding.springbootdemoexceptionhandler + * @description: 统一返回的 json 对象 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:42 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Data +@Builder +@NoArgsConstructor +@AllArgsConstructor +public class R { + private Integer code; + private String message; + private T data; + + public R(Status status) { + this.code = status.getCode(); + this.message = status.getMessage(); + } + + public static R success(Integer code, String message, Object data) { + return new R(code, message, data); + } + + public static R success() { + return new R(Status.OK); + } + + public static R success(String message) { + return success(message, null); + } + + public static R success(String message, Object data) { + return success(Code.SUCCESS.getCode(), message, data); + } + + public static R error(Integer code, String message, Object data) { + return new R(code, message, data); + } + + public static R error(Integer code, String message) { + return error(code, message, null); + } + + public static R error(DemoJsonException exception) { + return error(exception.getCode(), exception.getMessage()); + } +} +``` + +### error.html (在目录 `resources/templates` 下) + +```html + + + + + 统一页面异常处理 + + +

统一页面异常处理

+
+ + +``` + +### 其余代码 + +详情请参见本demo。 \ No newline at end of file diff --git a/spring-boot-demo-exceptionhandler/pom.xml b/spring-boot-demo-exceptionhandler/pom.xml new file mode 100644 index 0000000..b2c00b7 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/pom.xml @@ -0,0 +1,31 @@ + + + 4.0.0 + + spring-boot-demo-exceptionhandler + 0.0.1-SNAPSHOT + war + + spring-boot-demo-exceptionhandler + Demo project for Spring Boot + + + com.xkcoding + spring-boot-demo-parent + 0.0.1-SNAPSHOT + ../spring-boot-demo-parent/pom.xml + + + + + org.springframework.boot + spring-boot-starter-thymeleaf + + + + + spring-boot-demo-exceptionhandler + + + \ No newline at end of file diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/SpringBootDemoExceptionhandlerApplication.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/SpringBootDemoExceptionhandlerApplication.java new file mode 100644 index 0000000..9477068 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/SpringBootDemoExceptionhandlerApplication.java @@ -0,0 +1,12 @@ +package com.xkcoding.springbootdemoexceptionhandler; + +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + +@SpringBootApplication +public class SpringBootDemoExceptionhandlerApplication { + + public static void main(String[] args) { + SpringApplication.run(SpringBootDemoExceptionhandlerApplication.class, args); + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/controller/JsonController.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/controller/JsonController.java new file mode 100644 index 0000000..6b3a4b4 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/controller/JsonController.java @@ -0,0 +1,28 @@ +package com.xkcoding.springbootdemoexceptionhandler.controller; + +import com.xkcoding.springbootdemoexceptionhandler.domain.R; +import com.xkcoding.springbootdemoexceptionhandler.exception.DemoJsonException; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +/** + * 测试 json 异常处理 + * + * @package: com.xkcoding.springbootdemoexceptionhandler.controller + * @description: 测试 json 异常处理 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午2:08 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@RestController +@RequestMapping("/json") +public class JsonController { + + @GetMapping({"", "/"}) + public R index() { + throw new DemoJsonException(501, "DemoJsonException"); + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/controller/PageController.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/controller/PageController.java new file mode 100644 index 0000000..5c5861d --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/controller/PageController.java @@ -0,0 +1,28 @@ +package com.xkcoding.springbootdemoexceptionhandler.controller; + +import com.xkcoding.springbootdemoexceptionhandler.exception.DemoPageException; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.servlet.ModelAndView; + +/** + * TODO + * + * @package: com.xkcoding.springbootdemoexceptionhandler.controller + * @description: TODO + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午2:29 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Controller +@RequestMapping("/page") +public class PageController { + + @GetMapping({"", "/"}) + public ModelAndView index() { + throw new DemoPageException(600, "DemoPageException"); + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/domain/R.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/domain/R.java new file mode 100644 index 0000000..8619e1b --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/domain/R.java @@ -0,0 +1,63 @@ +package com.xkcoding.springbootdemoexceptionhandler.domain; + +import com.xkcoding.springbootdemoexceptionhandler.enums.Code; +import com.xkcoding.springbootdemoexceptionhandler.enums.Status; +import com.xkcoding.springbootdemoexceptionhandler.exception.DemoJsonException; +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Data; +import lombok.NoArgsConstructor; + +/** + * 统一返回的 json 对象 + * + * @package: com.xkcoding.springbootdemoexceptionhandler + * @description: 统一返回的 json 对象 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:42 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Data +@Builder +@NoArgsConstructor +@AllArgsConstructor +public class R { + private Integer code; + private String message; + private T data; + + public R(Status status) { + this.code = status.getCode(); + this.message = status.getMessage(); + } + + public static R success(Integer code, String message, Object data) { + return new R(code, message, data); + } + + public static R success() { + return new R(Status.OK); + } + + public static R success(String message) { + return success(message, null); + } + + public static R success(String message, Object data) { + return success(Code.SUCCESS.getCode(), message, data); + } + + public static R error(Integer code, String message, Object data) { + return new R(code, message, data); + } + + public static R error(Integer code, String message) { + return error(code, message, null); + } + + public static R error(DemoJsonException exception) { + return error(exception.getCode(), exception.getMessage()); + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/enums/Code.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/enums/Code.java new file mode 100644 index 0000000..b6b9289 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/enums/Code.java @@ -0,0 +1,25 @@ +package com.xkcoding.springbootdemoexceptionhandler.enums; + +import lombok.Getter; + +/** + * 状态码 + * + * @package: com.xkcoding.springbootdemoexceptionhandler.enums + * @description: 状态码 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:56 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Getter +public enum Code { + SUCCESS(200); + private Integer code; + + Code(Integer code) { + this.code = code; + } + +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/enums/Status.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/enums/Status.java new file mode 100644 index 0000000..2733ecf --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/enums/Status.java @@ -0,0 +1,26 @@ +package com.xkcoding.springbootdemoexceptionhandler.enums; + +import lombok.Getter; + +/** + * 返回状态 + * + * @package: com.xkcoding.springbootdemoexceptionhandler.enums + * @description: 返回状态 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:47 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Getter +public enum Status { + OK(200, "成功"), UNKNOW_ERROR(-1, "未知错误"); + private Integer code; + private String message; + + Status(Integer code, String message) { + this.code = code; + this.message = message; + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/exception/DemoJsonException.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/exception/DemoJsonException.java new file mode 100644 index 0000000..5dc3c46 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/exception/DemoJsonException.java @@ -0,0 +1,27 @@ +package com.xkcoding.springbootdemoexceptionhandler.exception; + +import lombok.Getter; + +/** + * 统一的 json 异常处理 + *

+ * 要继承 RuntimeException + *

+ * + * @package: com.xkcoding.springbootdemoexceptionhandler.exception + * @description: 统一的 json 异常处理 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:32 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Getter +public class DemoJsonException extends RuntimeException { + public Integer code; + + public DemoJsonException(Integer code, String message) { + super(message); + this.code = code; + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/exception/DemoPageException.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/exception/DemoPageException.java new file mode 100644 index 0000000..3e5d053 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/exception/DemoPageException.java @@ -0,0 +1,27 @@ +package com.xkcoding.springbootdemoexceptionhandler.exception; + +import lombok.Getter; + +/** + * 统一的页面异常处理 + *

+ * 要继承 RuntimeException + *

+ * + * @package: com.xkcoding.springbootdemoexceptionhandler.exception + * @description: 统一的页面异常处理 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:32 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@Getter +public class DemoPageException extends RuntimeException { + public Integer code; + + public DemoPageException(Integer code, String message) { + super(message); + this.code = code; + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/handler/DemoExceptionHandler.java b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/handler/DemoExceptionHandler.java new file mode 100644 index 0000000..62a3824 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/java/com/xkcoding/springbootdemoexceptionhandler/handler/DemoExceptionHandler.java @@ -0,0 +1,55 @@ +package com.xkcoding.springbootdemoexceptionhandler.handler; + +import com.xkcoding.springbootdemoexceptionhandler.domain.R; +import com.xkcoding.springbootdemoexceptionhandler.exception.DemoJsonException; +import com.xkcoding.springbootdemoexceptionhandler.exception.DemoPageException; +import lombok.extern.slf4j.Slf4j; +import org.springframework.web.bind.annotation.ControllerAdvice; +import org.springframework.web.bind.annotation.ExceptionHandler; +import org.springframework.web.bind.annotation.ResponseBody; +import org.springframework.web.servlet.ModelAndView; + +/** + * 自定义异常统一处理 + * + * @package: com.xkcoding.springbootdemoexceptionhandler.handler + * @description: 自定义异常统一处理 + * @author: yangkai.shen + * @date: Created in 2017/11/24 下午1:37 + * @copyright: Copyright (c) 2017 + * @version: 0.0.1 + * @modified: yangkai.shen + */ +@ControllerAdvice +@Slf4j +public class DemoExceptionHandler { + public static final String DEFAULT_ERROR_VIEW = "error"; + + /** + * 统一 json 异常处理 + * + * @param exception DemoJsonException + * @return 统一返回 json 格式 + */ + @ExceptionHandler(value = DemoJsonException.class) + @ResponseBody + public R jsonErrorHandler(DemoJsonException exception) { + log.error("【DemoJsonException】:{}", exception.getMessage()); + return R.error(exception); + } + + /** + * 统一 页面 异常处理 + * + * @param exception DemoPageException + * @return 统一跳转到异常页面 + */ + @ExceptionHandler(value = DemoPageException.class) + public ModelAndView pageErrorHandler(DemoPageException exception) { + log.error("【DemoPageException】:{}", exception.getMessage()); + ModelAndView view = new ModelAndView(); + view.addObject("message", exception.getMessage()); + view.setViewName(DEFAULT_ERROR_VIEW); + return view; + } +} diff --git a/spring-boot-demo-exceptionhandler/src/main/resources/application.yml b/spring-boot-demo-exceptionhandler/src/main/resources/application.yml new file mode 100644 index 0000000..9b72a64 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/resources/application.yml @@ -0,0 +1,9 @@ +server: + port: 8080 + context-path: /demo +spring: + thymeleaf: + mode: HTML5 + encoding: UTF-8 + content-type: text/html + cache: false \ No newline at end of file diff --git a/spring-boot-demo-exceptionhandler/src/main/resources/templates/error.html b/spring-boot-demo-exceptionhandler/src/main/resources/templates/error.html new file mode 100644 index 0000000..0b8c802 --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/main/resources/templates/error.html @@ -0,0 +1,11 @@ + + + + + 统一页面异常处理 + + +

统一页面异常处理

+
+ + \ No newline at end of file diff --git a/spring-boot-demo-exceptionhandler/src/test/java/com/xkcoding/springbootdemoexceptionhandler/SpringBootDemoExceptionhandlerApplicationTests.java b/spring-boot-demo-exceptionhandler/src/test/java/com/xkcoding/springbootdemoexceptionhandler/SpringBootDemoExceptionhandlerApplicationTests.java new file mode 100644 index 0000000..9cea0ee --- /dev/null +++ b/spring-boot-demo-exceptionhandler/src/test/java/com/xkcoding/springbootdemoexceptionhandler/SpringBootDemoExceptionhandlerApplicationTests.java @@ -0,0 +1,16 @@ +package com.xkcoding.springbootdemoexceptionhandler; + +import org.junit.Test; +import org.junit.runner.RunWith; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.junit4.SpringRunner; + +@RunWith(SpringRunner.class) +@SpringBootTest +public class SpringBootDemoExceptionhandlerApplicationTests { + + @Test + public void contextLoads() { + } + +} diff --git a/spring-boot-demo-parent/pom.xml b/spring-boot-demo-parent/pom.xml index f08e451..4e11ae4 100644 --- a/spring-boot-demo-parent/pom.xml +++ b/spring-boot-demo-parent/pom.xml @@ -18,6 +18,7 @@ ../spring-boot-demo-admin ../spring-boot-demo-logback ../spring-boot-demo-aoplog + ../spring-boot-demo-exceptionhandler ../spring-boot-demo-orm-jpa ../spring-boot-demo-orm-mybatis ../spring-boot-demo-cache-redis