行业资讯 2025年08月6日
0 收藏 0 点赞 623 浏览 1953 个字
摘要 :

文章目录 背景 探索思路 断点跟踪 java.lang.reflect.UndeclaredThrowableException retrofit 内部哪里有使用 突破口 “动态代理“ 总结 本文主要讲解关于如何使……




  • 背景
  • 探索思路
    • 断点跟踪
    • java.lang.reflect.UndeclaredThrowableException retrofit 内部哪里有使用
  • 突破口 “动态代理“
  • 总结

本文主要讲解关于如何使用Arthas 分析 java.lang.reflect.UndeclaredThrowableException 异常来源相关内容,让我们来一起学习下吧!

背景

使用了https://square.github.io/retrofit/ 包装接口,响应值不正常的时候抛出一个异常堆栈
异常堆栈从哪里来的?不应该是 com.fasterxml.jackson.core.JsonParseException 异常? 怎么会被包装成了 java.lang.reflect.UndeclaredThrowableException?

Java.lang.reflect.UndeclaredThrowableException
    at com.sun.proxy.$Proxy60.tokenAuth(Unknown Source)
    at com.example.controller.AccountTestController.auth(AccountTestController.java:114)
....
Caused by: com.fasterxml.jackson.core.JsonParseException: Unrecognized token \'ok\': was expecting (JSON String, Number, Array, Object or token \'null\', \'true\' or \'false\')
 at [Source: (okhttp3.ResponseBody$BomAwareReader); line: 1, column: 3]
    at com.fasterxml.jackson.core.JsonParser._constructError(JsonParser.java:2391)
....

探索思路

模拟不正常的响应值导致反序列化失败.. 自己写一个mock 服务,eg 返回对象 返回一个string

断点跟踪

JacksonResponseBodyConverter.convert 确实是 抛出了一个异常 com.fasterxml.jackson.core.JsonParseException,之后就没有之后了.. 这个方法不可行,这里面临一个问题,由于动态代理的代码是动态生成的没办法进行调试。

java.lang.reflect.UndeclaredThrowableException retrofit 内部哪里有使用

根据推断 内部只有一个地方使用,设置断点发现没有调用实例进入.. 发现这个思路走错了..

突破口 “动态代理“

at com.sun.proxy.$Proxy60.tokenAuth(Unknown Source) Unknown Source ? 利用工具反编译查看一下源码ok?

curl -L \"https://arthas.aliyun.com/as.sh\" >as.sh; chmod a+x as.sh; ./as.sh 安装arthas 执行命令 jad com.sun.proxy.$Proxy60 tokenAuth

反编译的结果

public final BaseResponse tokenAuth(AccountContextAccountContext,TokenAuthRequestTokenAuthRequest) {
        try {
            return (BaseResponse)this.h.invoke(this, m5, new Object[]{AccountContext,TokenAuthRequest});
        }
        catch (Error | RuntimeException throwable) {
            throw throwable;
        }
        catch (Throwable throwable) {
            throw new UndeclaredThrowableException(throwable);
    }
}

原来是动态代理这里进行了包装处理了RuntimeException 原样返回,Throwable 会进行包装

查询了一下相关bolg java.lang.reflect.UndeclaredThrowableException的解决 基本上就是动态代理的问题

总结

通过对于异常的深入探究,跟踪了解到了实现原理, “工欲善其事,必先利其器”。

以上就是关于如何使用Arthas 分析 java.lang.reflect.UndeclaredThrowableException 异常来源相关的全部内容,希望对你有帮助。欢迎持续关注潘子夜个人博客(www.panziye.com),学习愉快哦!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/10016.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号