摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢!

“年轻人不要怕表现,要敢于出来表现,但还是那句话,要有正确的度,你的表现是分析问题和解决问题的能力。”

– 《你凭什么做好互联网》

本文提纲
一、异常统一处理的使用场景
二、运行 springboot-validation-over-json 工程
三、springboot-validation-over-json 工程代码详解

一、异常统一处理的使用场景

在前后端分离开发中,经常用 HTTP over JSON 作为服务进行前后端联调对接。这里简单介绍下为啥前后端分离开发?我想到如下:

1.低耦合,责权分离,模块化。前后端之间利用轻量级协议对接耦合。
2.便于敏捷开发:后端给出 api 文档 -> 前端根据文档,mock出数据开发 ;同时,后端实现业务逻辑。
3.微服务尤其适用

这时候 HTTP over JSON 形式中很多涉及到返回码,错误码相关的处理。比如xxx参数不完整,权限不足,用户不存在等。

怎么统一处理认为是异常的场景呢?
利用的是 Spring 4.x 提供的 RestControllerAdvice。这里做下说明,也可以根据 ControllerAdvice 去实现。这里案例是 HTTP over JSON 模式,所以直接利用
RestControllerAdvice ,控制层通知器,这里用于统一拦截异常,进行响应处理。工作模式,如图:

二、运行 springboot-validation-over-json 工程

运行环境:JDK 7 或 8,Maven 3.0+
技术栈:SpringBoot 1.5+(内涵 Spring 4.x)

1.git clone 下载工程 springboot-learning-example
项目地址见 GitHub – https://github.com/JeffLi1993/springboot-learning-example:

1
git clone git@github.com:JeffLi1993 /springboot-learning-example .git

然后,Maven 编译安装这个工程:

1
2
cd springboot-learning-example
mvn clean install

2.运行 springboot-validation-over-json 工程
右键运行 springboot-validation-over-json 工程 Application 应用启动类的 main 函数。默认端口 8080

3.访问案例
a. 参数不完整案例:
访问浏览器打开下面链接,可得到以下 JSON 返回
http://localhost:8080/api/city?cityName=

1
2
3
4
5
{
     "code" : "000001" ,
     "message" : "params no complete" ,
     "result" : null
}

b. 成功案例:
访问浏览器打开下面链接,可得到以下 JSON 返回
http://localhost:8080/api/city?cityName=%E6%B8%A9%E5%B2%AD%E5%B8%82

1
2
3
4
5
6
7
8
9
10
{
     "code" : "0" ,
     "message" : "success" ,
     "result" : {
         "id" : 1,
         "provinceId" : 2,
         "cityName" : "温岭" ,
         "description" : "是我的故乡"
     }
}

三、springboot-validation-over-json 工程代码详解

代码详解提纲:
a.控制层通知器
b.响应码设计

同样,代码共享在我的 GitHub 上:
https://github.com/JeffLi1993/springboot-learning-example/tree/master/springboot-validation-over-json

首先,工程代码目录如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
├── pom.xml
└── src
     └── main
         └── java
             └── org
                 └── spring
                     └── springboot
                         ├── Application.java
                         ├── constant
                         │   └── CityErrorInfoEnum.java
                         ├── result
                         │   ├── ErrorInfoInterface.java
                         │   ├── GlobalErrorInfoEnum.java
                         │   ├── GlobalErrorInfoException.java
                         │   ├── GlobalErrorInfoHandler.java
                         │   └── ResultBody.java
                         └── web
                             ├── City.java
                             └── ErrorJsonController.java

a.控制层通知器
GlobalErrorInfoHandler.java 代码如下:

1
2
3
4
5
6
7
8
9
10
11
@RestControllerAdvice
public class GlobalErrorInfoHandler {
@ExceptionHandler (value = GlobalErrorInfoException. class )
public ResultBody errorHandlerOverJson(HttpServletRequest request,
GlobalErrorInfoException exception) {
     ErrorInfoInterface errorInfo = exception.getErrorInfo();
     ResultBody result = new ResultBody(errorInfo);
     return result;
}
}

@ExceptionHandler 注解,标记了使用 errorHandlerOverJson() 方法来处理 GlobalErrorInfoException 异常。
@RestControllerAdvice 是 @ControllerAdvice 和 @ResponseBody 的语义结合。是控制器增强,直接返回对象。这里用于统一拦截异常,然后返回错误码对象体。
@ResponseBody 作用: 该注解用于将 Controller 的方法返回的对象,通过适当的 HttpMessageConverter 转换为指定格式后,写入到 Response 对象的 body 数据区。

b.响应码设计
简单讲讲,这里定义了一个错误码接口,全局错误码枚举和各个业务错误码枚举去实现接口,并用枚举值枚举出错误码及错误码消息列表。如图:

四、小结

如果实战中,大家遇到什么,或者建议《Spring boot 那些事》还需要一起交流的。请点击留言。

推荐书《腾讯传》,其中几章写的很不错。

欢迎扫一扫我的公众号关注 — 及时得到博客订阅哦!
— http://www.bysocket.com/ —
— https://github.com/JeffLi1993 —

Spring Boot HTTP over JSON 的错误码异常处理相关推荐

  1. spring boot整合SpringSecurity-03 自定义报错信息

    spring boot整合SpringSecurity 目录 spring boot整合SpringSecurity-01入门 spring boot整合SpringSecurity-02 基于Ser ...

  2. Spring Boot下使用JPA报错:'hibernate.dialect' not set的解决办法

    问题现象: Spring Boot下使用JPA报错:'hibernate.dialect' not set 原因是: 没有设置数据库方言导致的 解决方案: 1.如果配置文件格式为application ...

  3. 创建Spring boot项目运行出现报错: java: 无效的源发行版: 14

    触发场景:创建Spring boot项目运行出现报错\ 首先在左边的项目中选择pom.xml文件 找到这行,把中间的版本改成自己下载的java版本 我的是1.8,改好后再点maven刷新即可

  4. 格式化json_在Spring Boot中格式化JSON日期

    1.概述 在本教程中,我们将展示如何在Spring Boot应用程序中格式化JSON日期字段. 我们将探讨使用Jackson格式化日期的各种方法,它被Spring Boot用作默认的JSON处理器. ...

  5. Spring Boot项目@RunWith注解报错

    Spring Boot项目中,新添加test类,使用@RunWith注解报错,肯定是项目中没有添加依赖. 解决办法: 1.pom.xml引入依赖 <!--添加junit环境的jar包--> ...

  6. spring boot项目IDEA启动报错问题解决

    IDEA代码编辑器发展很快,现在很多都从Eclipse转到IDEA来了,我就是其中一个,感觉IDEA黑色的主题我感觉很不错 :wink: 好了,下面切入正题 Eclipse启动Spring boot没 ...

  7. 亲测有效:spring boot中parent节点报错解决办法

    今天中午开始学习spring boot,结果一中午都卡在了pom.xml配置上.因为spring boot需要引入一个parent project, pom.xml文件中: <!-- Inher ...

  8. spring boot 转xml格式报错解决方法_芋道 Spring Boot MyBatis 入门(一)之 MyBatis + XML...

    摘要: 原创出处 http://www.iocoder.cn/Spring-Boot/MyBatis/「芋道源码」欢迎转载,保留摘要,谢谢! 1. 概述 2. MyBatis + XML 2.1 引入 ...

  9. spring boot jar包替换报错之Unable to open nested entry 'BOOT-INF/lib/cache-api-0.4.jar'.

    spring boot用layout ZIP打出来的包能够支持外部classpath,但是当用rar/7zip替换其中的jar后,报下列错误: Unable to open nested entry ...

最新文章

  1. Tomcat 1099端口占用重启无效,查不到进程,改换端口无效解决方案
  2. 官宣!中央广播电视总台《2021年春节联欢晚会》总导演组公布
  3. python,制作山东省的地图 热力图
  4. MySQL从入门到精通50讲(一)-MySQL数据库操作创建数据库及删除数据库
  5. java怎么写事件listener_java 事件监听器ActionListener
  6. 终于解决H3C交换机reset saved-configuration后不能启动的问题
  7. c++简单的加法函数
  8. Python基础——try(异常处理)
  9. 视觉系统设计实例(halcon-winform)-10.PLC通讯
  10. Unix-Center.Net需要你的帮助
  11. 搜集各种稀奇古怪的编码
  12. Fabric2.3分布式部署(fabric-ca)
  13. Win10优化:系统文件Hiberfil.sys介绍
  14. 5G NR的新特征—超低时延
  15. 快递鸟即时查询(PHP)
  16. 基于JSON+JQuery实现的多条件筛选功能(类似京东和淘宝功能)
  17. Flask外部访问服务器最简单的操作
  18. python视频教程410集免费_Python Web开发—进阶提升 490集超强Python视频教程 真正零基础学习Python视频教程...
  19. Google benchmark使用手册及范例
  20. java接口设计规范_关于团队API接口规范设计

热门文章

  1. Unity 大面积草风吹动效果+受人物影响
  2. hive hive beeline常用参数
  3. 深圳企业选择深圳SEO外包的理由
  4. 今日份安利:手机上怎么去图片水印
  5. 基于PT8.2网关的二氧化碳监测及联动控制
  6. 2023年4月国产数据库大事记-墨天轮
  7. 分享一个react 图片上传组件 支持OSS 七牛云
  8. 腾讯云IM集成(so easy)
  9. PCIe | 基础知识点扫盲
  10. 抖音小店无货源玩法分享(五)抖店类目该如何选择