记一次线上环境JAR冲突导致程序报错org.springframework.web.util.NestedServletException

一、问题描述

有个文件导入功能,用到了Hutool 的加密解密功能,本地运行完全可以,但是线上报错:“org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: Could not initialize class cn.hutool.crypto.SmUtil.........”,如下图所示

提示没有找到类NoClassDefFoundError,打开对应的JAR,查看class 是存在的,于是想到了JAR冲突,网上也有人说因为hutool-all 和hutool-core 两个包冲突,可是检查了我的项目,并没有pom 引入了hutool-core ???

难道是服务器的JAVA 环境问题? 于是本地打包后,启动项目,仍然报错,看来确实是因为maven 打包后导致的jar 冲突了,问题的关键点就是要找出冲突的jar 到底是哪个?

二、远程DEBUG

既然本地运行没有问题,只有打包后存在问题,那么就只能用到idea 的远程DEBUG 功能了 。

1、打开 IDEA,点击 Run > Edit Configurations。

2、点击左上角的 +,选择 Remote JVM Debug。

3、配置调试参数:

  • Name:配置名称(随意)。
  • Host:远程服务器的 IP 地址或域名。
  • Port:远程服务器 JVM 的调试端口(如 5005),与你项目启动端口不要一致
  • 注意一下JDK 要与线上环境一致

点击 Apply 保存配置。

4、把红框这段代码当做启动参数添加到线上环境启动脚本里

-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005

例如 java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -jar  your-project.jar

参数说明:

  • agentlib:jdwp:启用 JDWP 协议。
  • transport=dt_socket:使用 Socket 进行通信。
  • server=y:将当前 JVM 配置为调试服务器,等待调试客户端连接。
  • suspend=n:JVM 是否在启动时挂起,n 表示不挂起,y 表示挂起直到客户端连接。
  • address=*:5005:指定调试监听的端口。*:5005表示监听所有IP地址的5005端口,也可以指定监听xxx.xxx.xxx.xxx:5005

5、启动远程的线上项目后,记得本地idea 也启动监听

6、在报错的代码出打上断点,这时候访问远程的线上接口,断点会自动打进idea了

我的问题就是代码53行报错,这时候选中 SmUtil.sm2(privateKey, null);idea快捷键alt+F8

可见错误信息为:

class "org.bouncycastle.asn1.ASN1Encodable"'s signer information does not match signer information of other classes in the same package

现在找到了错误就是ASN1Encodable这个问题,在idea 里面双击shift ,搜寻这个类都存在哪些包里

好吧,浮出水面了,有两个版本分别是bcprov-jdk14-138.jar 和 bcprov-jdk18on-1.73.jar

于是我手动在打包好的 lib 目录里面删除了较低版本bcprov-jdk14-138.jar  ,项目重启,运行,测试通过

三、查看依赖关系,从项目上解决

方法一: 上面已经找到冲突的jar 了,接下来要找到究竟是在项目哪些jar 间接引用了这个bcprov-jdk14-138.jar,因为pom 里面搜不到

这里我们可以使用idea插件中的依赖分析插件,来帮助我们寻找冲突的jar包

成功下载后,找到我们的pom 文件,进行分析,如下图

由此定位到了是core-renderer 这个包引用了bcprov-jdk14-138.jar ,确定这个类没有被实际使用,直接排除就好了

方法二:如果不想下载插件,也可以用idea 自带的maven分析视图,注意要在下面选中对应pom

找到后,如需删除直接选中右键,直接exclude 就好,会直接在pom 文件里面自动添加一下这段

<exclusions><exclusion><artifactId>bcprov-jdk14</artifactId><groupId>bouncycastle</groupId></exclusion></exclusions>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/73463.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么快速部署Sock5代理到ubuntu云服务器

使用 Dante (推荐) 1. 安装 Dante bash Copy sudo apt update sudo apt install dante-server -y 2. 配置 Dante 编辑配置文件 /etc/danted.conf&#xff1a; bash Copy sudo nano /etc/danted.conf 替换为以下内容&#xff08;按需修改端口和认证&#xff09;&#…

华为OD机试2025A卷 - 游戏分组/王者荣耀(Java Python JS C++ C )

最新华为OD机试 真题目录:点击查看目录 华为OD面试真题精选:点击立即查看 题目描述 2020年题: 英雄联盟是一款十分火热的对战类游戏。每一场对战有10位玩家参与,分为两组,每组5人。每位玩家都有一个战斗力,代表着这位玩家的厉害程度。为了对战尽可能精彩,我们需要…

OpenRAND可重复的随机数生成库

OpenRAND 是一个 C++ 库,旨在通过提供强大且可复制的随机数生成解决方案来促进可重复的科学研究。它是一个简单的仅头文件库,性能可移植,统计稳健,并且易于集成到任何 HPC 计算项目中。 特征 跨平台支持:OpenRAND 旨在跨各种平台无缝工作,包括 CPU 和 GPU。其仅标题库设计…

接口/UI自动化面试题

一、UI自动化 1.1、接口和UI自动化有多少用例&#xff1f; 回答策略&#xff1a;根据接口设定用例&#xff0c;100个接口&#xff0c;自动化case在1500-2000左右。结合自身的项目&#xff0c;回答覆盖的主功能流程。 示例&#xff1a; 接口自动化的测试case一般需要根据接口数…

使用Docker部署RabbitMQ

第一步&#xff1a;安装 RabbitMQ # 1. 拉取镜像 docker pull rabbitmq:3.12.0-management# 2. 启动容器&#xff08;开放端口 数据持久化&#xff09; docker run -d \--nameshare_rabbitmq \-p 5672:5672 \ # AMQP 协议端口-p 15672:15672 \ # 管理界面端口…

2.基于多线程的TCP服务器实现

目录 1. 简单分析之前的代码 2. 多线程服务器设计 2.1 C11线程的基本使用 2.2 服务器主体逻辑 3. 错误处理的封装 4. 完整的代码实现 客户端代码&#xff08;client.cpp&#xff09; 服务器代码&#xff08;server.cpp&#xff09; 5. 运行方式 在我们预想中&#xff…

Python Web 框架 Django、Flask 和 FastAPI 对比

在探索 Python Web 框架时&#xff0c;Django、Flask 和 FastAPI 无疑是最常被提及的名字。根据我们最新的 Python 开发者调查&#xff0c;这三大框架继续稳坐后端 Web 开发的热门宝座。它们均为开源项目&#xff0c;并且与 Python 的最新版本无缝兼容。然而&#xff0c;面对不…

SQL Server数据库表删除分区

在 SQL Server 中删除分区并将表恢复到非分区状态&#xff0c;需按以下步骤操作&#xff1a; 一、合并所有分区 1. 检查现有分区结构 首先确认表的分区方案和分区函数&#xff1a; -- 查看分区方案 SELECT * FROM sys.partition_schemes;-- 查看分区函数 SELECT * FROM sys…

信息安全和病毒防护——安全协议关于SSL和TLS协议的补充说明

文章目录 SSL与TLS的关系SSL与TLS的核心区别SSL/TLS的典型应用安全建议总结SSL与TLS的关系 SSL(Secure Sockets Layer,安全套接层)和TLS(Transport Layer Security,传输层安全)是同一技术体系的演进版本,而非完全独立的协议。其发展历程如下: SSL 1.0(1994):未公开…

[原创](Modern C++)现代C++的关键性概念: 多维数组的下标引用.

[作者] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共24年] 职业生涯: 22年 开发语言: C/C、80x86ASM、Object Pascal、Objective-C、C#、R、Python、PHP、Perl、 开发工具: Visual Studio、Delphi、XCode、C …

从零构建大语言模型全栈开发指南:第二部分:模型架构设计与实现-2.2.3实战案例:在笔记本电脑上运行轻量级LLM

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 实战案例:在笔记本电脑上运行轻量级LLM2.2.3 模型架构设计与实现1. 环境与工具准备1.1 硬件要求1.2 软件栈选择2. 轻量级模型架构设计2.1 模型参数配置2.2 关键技术优化3. 实战流程3.1 数据准备流程3.2…

工业软件的破局与重构:从技术依赖到自主创新的未来路径

工业软件作为现代工业的“神经与大脑”&#xff0c;不仅是制造业数字化转型的核心工具&#xff0c;更是国家工业竞争力的战略制高点。近年来&#xff0c;中国工业软件市场在政策驱动与技术迭代中迅猛发展&#xff0c;但核心技术受制于人的困境仍待突破。如何实现从“跟跑”到“…

歌曲缓存相关功能

1. 核心组件 MusicCacheManager (音乐缓存管理器) 单例模式&#xff1a;确保全局只有一个实例&#xff0c;方便管理。 private static var instance: MusicCacheManager?static func shared() -> MusicCacheManager {if instance nil {instance MusicCacheManager()}ret…

解决 Ubuntu/Debian 中 `apt-get` 报错 “无法获得锁 /var/lib/dpkg/lock“

问题描述 在 Ubuntu/Debian 系统中运行 sudo apt-get install 或 sudo apt update 时&#xff0c;遇到以下错误&#xff1a; E: 无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用) E: 无法锁定管理目录(/var/lib/dpkg/)&#xff0c;是否有其他进程正占用它&#…

阿里开源的免费数据集成工具——DataX

企业里真实的数据流转是什么样子的呢&#xff1f; 左侧描述了一个企业真实的样子&#xff0c;我们总是需要把数据从一个地方搬到另一个地方&#xff0c;最后就是搬来搬去搬成了一张张解不开的网。 右侧则表达了使用DataX为中心实现数据的同步。 什么是DataX DataX是一个异构…

26考研——图_图的遍历(6)

408答疑 文章目录 三、图的遍历图的遍历概述图的遍历算法的重要性图的遍历与树的遍历的区别图的遍历过程中的注意事项避免重复访问遍历算法的分类遍历结果的不唯一性 广度优先搜索广度优先搜索&#xff08;BFS&#xff09;概述BFS 的特点广度优先遍历的过程示例图遍历过程 BFS …

前端解决方案:实现网页截图并导出PDF功能

前端解决方案&#xff1a;实现网页截图并导出PDF功能 在前端开发中&#xff0c;我们经常会遇到需要将网页内容导出为PDF的需求。本文将以一个准考证预览和导出的例子&#xff0c;带你一步步实现这个功能。我们会处理包括跨域图片、Canvas绘图、PDF生成等多个技术要点。 一、基…

【MySQL】表操作

表操作 一、创建表 1、语句2、语句介绍3、注意事项4、介绍5、示例 二、查看表结构 1、语句2、介绍3、返回的信息4、示例 三、添加字段 1、语句2、语句介绍3、示例 四、修改 1、语句2、语句介绍3、示例 五、删除 1、语句2、示例 六、修改表名 1、语句2、语句介绍3、示例 七、删…

[新闻.AI]国产大模型新突破:阿里开源 Qwen2.5-VL-32B 与 DeepSeek 升级 V3 模型

&#xff08;本文借助 Deepseek-R1 协助生成&#xff09; 在2025年3月24日至25日的短短24小时内&#xff0c;中国AI领域迎来两大重磅开源更新&#xff1a;阿里通义千问团队发布多模态大模型Qwen2.5-VL-32B-Instruct&#xff0c;而DeepSeek则推出编程能力大幅提升的DeepSeek-V3…

深入剖析C# List<T>的底层实现与性能奥秘

一、动态数组的本质&#xff1a;List的架构设计 在C#的集合类型体系中&#xff0c;List作为最常用的线性数据结构&#xff0c;其核心实现基于动态数组机制。与传统数组不同&#xff0c;List通过智能的容量管理策略&#xff0c;在保持数组高速随机访问优势的同时&#xff0c;突…