前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Spring Cloud Gateway过滤器精确控制异常返回(实战,控制http返回码和message字段)

Spring Cloud Gateway过滤器精确控制异常返回(实战,控制http返回码和message字段)

作者头像
程序员欣宸
发布2021-12-07 09:44:54
4500
发布2021-12-07 09:44:54
举报
文章被收录于专栏:实战docker

本篇概览

在这里插入图片描述
在这里插入图片描述
  • 为了简单起见,本篇不再新增maven子工程,而是基于前文创建的子工程gateway-change-body,在这里面继续写代码;

源码下载

  • 本篇实战中的完整源码可在GitHub下载到,地址和链接信息如下表所示(https://github.com/zq2599/blog_demos):

名称

链接

备注

项目主页

https://github.com/zq2599/blog_demos

该项目在GitHub上的主页

git仓库地址(https)

https://github.com/zq2599/blog_demos.git

该项目源码的仓库地址,https协议

git仓库地址(ssh)

git@github.com:zq2599/blog_demos.git

该项目源码的仓库地址,ssh协议

  • 这个git项目中有多个文件夹,本篇的源码在spring-cloud-tutorials文件夹下,如下图红框所示:
在这里插入图片描述
在这里插入图片描述
  • spring-cloud-tutorials文件夹下有多个子工程,本篇的代码是gateway-change-body,如下图红框所示:
在这里插入图片描述
在这里插入图片描述

第一种:抛出ResponseStatusException异常

  • 打开gateway-change-body工程的RequestBodyRewrite.java文件,改动如下图红框,如果请求body不含user-id参数就返回Mono.error,入参是ResponseStatusException异常,设置了返回码为400,message为一段中文描述:
在这里插入图片描述
在这里插入图片描述
  • 接下来运行nacos、provider-hello工程、gateway-change-body工程
  • 用postman发请求试试,请求和响应的详情如下图:
在这里插入图片描述
在这里插入图片描述
  • 从上图可见,返回码为400,和我们设定的一样,但是message却为空,这是怎么回事呢?按照咱们的设定,这里应该显示请求参数必须包含user-id字段,看来咱们遇到一只拦路虎了

小小拦路虎

  • 咱们代码中,抛异常的时候设定message内容如下图红框所示,但运行的时候返回的是空字符串,这是怎么回事呢?
在这里插入图片描述
在这里插入图片描述
  • 来看DefaultErrorWebExceptionHandler.isIncludeMessage方法,看下图红框中的那个errorProperties,您会不会恍然大悟:这不就是springboot配置中的erro配置嘛!
在这里插入图片描述
在这里插入图片描述
  • 修改工程的配置文件,红框内是新增的配置:
在这里插入图片描述
在这里插入图片描述
  • 再用postman试试,如下图,这一次,status、message、exception、trace齐聚一堂,完全符合预期:
在这里插入图片描述
在这里插入图片描述
  • 看来第一种方法是可行的:返回ResponseStatusException类型的异常;

第二种:自定义异常,带ResponseStatus注解

  • 接下来试试第二种方法:通ResponseStatus注解
  • 首先新建一个异常类MyGatewayException.java,使用了ResponseStatus,在里面配置返回码和message内容,这次的返回码用的是403:
代码语言:javascript
复制
package com.bolingcavalry.changebody.exception;

import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.ResponseStatus;

@ResponseStatus(code = HttpStatus.FORBIDDEN, reason = "user-id字段不能为空")
public class MyGatewayException extends Exception {
}
  • 编码完成,重启应用,然后再发一次请求,如下图,返回码和message内容都符合预期:
在这里插入图片描述
在这里插入图片描述
  • 至此,两种最简单的方式都完成验证,一般情况下已经满足要求:将错误信息准确传递给调用方

留有瑕疵

  • 聪明的您应该已发现上述两种方案有瑕疵:返回body的格式和字段都是固定的,如果项目中对返回body的内容有严格要求,例如只允许code、message、data三个字段,其余字段一律不能返回,此时又该怎么办呢?
  • 似乎需要一种方法,让咱们可以随心所欲的设置body内容,篇幅所限,这种终极的解决方式就留在下一篇吧,敬请期待,欣宸原创,必不辜负您…
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/09/11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 本篇概览
  • 源码下载
  • 第一种:抛出ResponseStatusException异常
  • 小小拦路虎
  • 第二种:自定义异常,带ResponseStatus注解
  • 留有瑕疵
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档