maven:java.lang.NoClassDefFoundError: org/apache/commons/io/Charsets

简介:

今天从git上down了一个第三方jar ,这个jar里面用到了

1
2
  String resultUrl = String.format(url, 
           URLEncoder.encode(ticket, Charsets.UTF_8.name()));


然而执行到这里的时候,就报错了:

java.lang.NoClassDefFoundError: org/apache/commons/io/Charsets


第一反应就是jar包冲突了,看了下依赖,果然是有问题,如图所示:


common-fileupload 1.3.1的版本依赖的commons-io 2.2,而第三方jar依赖的是common-io 2.4

wKioL1eKMBKA0OYUAAFBwtAygvw212.jpg-wh_50

于是果断的:

1
2
3
4
5
6
< exclusions >
                 < exclusion >
                     < groupId >commons-io</ groupId >
     < artifactId >commons-io</ artifactId >
                 </ exclusion >
             </ exclusions >


发现并不管用,于是跟踪源码进去看看,看这个Charsets类到底是在哪个包下面:


源码里面引入的是:

import org.apache.commons.io.Charsets;


而common-io 2.2下面是没有这个Charsets的,commons-io-2.5 下面就有了这个类

wKioL1eKMVXw21d2AADGDgonI5g566.jpg-wh_50

wKiom1eKMZyiXGDEAAI4LxmziCQ317.jpg-wh_50


于是打算升级common-io的版本,

wKioL1eKMebwk4slAAFpYFgC-YI461.jpg-wh_50

看了下 这个common-fileupload-1.3.2 依赖的common-io的版本已经升到2.5了。

1
2
3
4
5
6
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
         < dependency >
             < groupId >commons-io</ groupId >
             < artifactId >commons-io</ artifactId >
             < version >2.5</ version >
         </ dependency >


因此问题得以解决。







 本文转自 w156445045 51CTO博客,原文链接:http://blog.51cto.com/enetq/1827028,如需转载请自行联系原作者

相关文章
|
2月前
|
Java Maven Spring
SpringBoot 系列之 Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resource
这篇文章描述了在使用Maven构建Spring Boot项目时遇到的`maven-resources-plugin`插件版本问题导致的编译失败,并提供了通过修改插件版本至3.1.0来解决这个问题的方法。
SpringBoot 系列之 Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resource
|
2月前
|
消息中间件 Java Kafka
【Azure 事件中心】在微软云中国区 (Mooncake) 上实验以Apache Kafka协议方式发送/接受Event Hubs消息 (Java版)
【Azure 事件中心】在微软云中国区 (Mooncake) 上实验以Apache Kafka协议方式发送/接受Event Hubs消息 (Java版)
|
4月前
|
消息中间件 存储 Java
深度探索:使用Apache Kafka构建高效Java消息队列处理系统
【6月更文挑战第30天】Apache Kafka是分布式消息系统,用于高吞吐量的发布订阅。在Java中,开发者使用Kafka的客户端库创建生产者和消费者。生产者发送序列化消息到主题,消费者通过订阅和跟踪偏移量消费消息。Kafka以持久化、容灾和顺序写入优化I/O。Java示例代码展示了如何创建并发送/接收消息。通过分区、消费者组和压缩等策略,Kafka在高并发场景下可被优化。
107 1
|
4月前
|
Java 数据库连接 Apache
深入理解Apache Commons Pool2池化技术
深入理解Apache Commons Pool2池化技术
|
3月前
|
easyexcel Java Apache
EasyExcel导入的时候报错Caused by: java.lang.NoClassDefFoundError: org/apache/poi/poifs/filesystem/File
EasyExcel导入的时候报错Caused by: java.lang.NoClassDefFoundError: org/apache/poi/poifs/filesystem/File
204 0
|
3月前
|
Java Maven
Cannot resolve plugin org.apache.maven.plugins:maven-site-plugin:3.3
Cannot resolve plugin org.apache.maven.plugins:maven-site-plugin:3.3
|
3月前
|
Java 应用服务中间件 API
如何安装与使用Java EE 8、Servlet 3.0及Apache Maven进行高效开发
【7月更文第1天】搭建高效Java EE 8开发环境,包括安装JDK、选择WildFly或Payara Server作为应用服务器,以及安装Apache Maven。使用Maven创建Servlet 3.0 Web项目,编写 HelloWorldServlet,打包部署到服务器,通过访问特定URL测试应用。这一流程助力开发者实现快速原型和大型项目开发。
83 0
|
2月前
|
存储 消息中间件 Java
Apache Flink 实践问题之原生TM UI日志问题如何解决
Apache Flink 实践问题之原生TM UI日志问题如何解决
36 1
|
25天前
|
SQL 消息中间件 关系型数据库
Apache Doris Flink Connector 24.0.0 版本正式发布
该版本新增了对 Flink 1.20 的支持,并支持通过 Arrow Flight SQL 高速读取 Doris 中数据。

推荐镜像

更多
下一篇
无影云桌面