Shabusi_GGh 2024-03-06 19:43 采纳率: 46.7%
浏览 8

抛出自定义异常,通过全局异常处理,本地环境和线上环境不同效果

抛出自定义异常,通过全局异常处理。本地环境正常显示异常message,而线上环境则是接口报红-500错误。
同一个代码,不知道哪个配置出现了问题。。

img

img

  • 写回答

6条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-03-06 19:44
    关注

    引自免费微信小程序:皆我百晓生

    在Java项目中,抛出自定义异常并通过全局异常处理器处理时,在本地环境和线上环境出现不同效果的问题,通常可能由以下几个方面引起:

    1. 日志级别设置:线上环境的日志级别可能设置得较高(如ERROR级别),而自定义异常的堆栈信息被抑制了。确保线上环境的日志配置文件中,至少将应用服务的日志级别设置为INFO或者DEBUG,以便能输出详细的异常信息。
    # logback配置示例
    <logger name="your.package.name" level="INFO"/>
    
    1. 全局异常处理器差异:检查线上环境与本地环境使用的全局异常处理器是否一致,以及它们的实现逻辑是否有差异。确保线上环境的全局异常处理器正确捕获并处理了自定义异常,并且返回了合适的HTTP状态码和错误信息。
    @ControllerAdvice
    public class GlobalExceptionHandler {
    
        @ExceptionHandler(value = CustomException.class)
        @ResponseBody
        public ResponseEntity handleCustomException(CustomException e) {
            return new ResponseEntity<>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
        }
    }
    
    1. 服务器容器配置:线上服务器(如Tomcat、Jetty)可能对未处理异常有特殊处理机制,导致直接返回500错误,而没有正常调用全局异常处理器。需要确认服务器容器的配置是否正确,允许Spring Boot的全局异常处理器生效。

    2. 代码版本不一致:请核实本地和线上的代码版本是否完全同步,以避免因代码部署问题导致的不同行为。

    3. 环境变量或配置文件差异:某些运行时配置(如application.properties或环境变量)可能影响到异常处理逻辑,确保线上环境的相关配置与本地保持一致。

    4. 安全性限制或过滤器拦截:线上环境可能存在安全策略或自定义过滤器,这些可能会拦截异常信息,导致无法正确显示。检查是否存在此类情况。

    若以上排查无误,请进一步分析线上环境的具体错误日志,这有助于找到问题所在。同时,在测试期间,可以尝试简化问题,仅抛出自定义异常看线上是否能够正常响应,逐步添加其他中间件、过滤器等组件来定位问题源。

    评论

报告相同问题?

问题事件

  • 创建了问题 3月6日

悬赏问题

  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值