首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >解决java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound

解决java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound

原创
作者头像
大盘鸡拌面
发布于 2023-11-03 01:46:06
发布于 2023-11-03 01:46:06
81102
代码可运行
举报
文章被收录于专栏:软件研发软件研发
运行总次数:2
代码可运行

解决​​java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path​

在使用Java编程的过程中,我们常常会遇到各种各样的错误和异常。其中一个常见的问题是在依赖库中出现了相互冲突的情况,比如在使用日志框架时可能会出现​​java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path​​的异常。这个异常是由于在项目的依赖中同时存在了​​log4j-over-slf4j.jar​​和​​slf4j-log4j12.jar​​这两个不兼容的库引起的。

问题产生的原因

这个问题的根本原因是存在两个不同的日志框架冲突,分别是​​Log4j​​和​​Slf4j​​。​​Log4j​​是一个Java日志框架,而​​Slf4j​​(Simple Logging Facade for Java)是一个简单的日志门面,它提供了一个统一的API,可以用于不同的日志框架。在某些情况下,我们可能需要使用​​Log4j​​作为日志框架,但依赖库中同时引入了​​Log4j​​和​​Slf4j​​,导致冲突。

解决方法

解决这个问题的方法很简单,我们只需要移除或者排除其中一个库的依赖即可。下面是两种解决方法:

方法一:移除​​Slf4j​​的依赖

如果你已经决定使用​​Log4j​​作为日志框架,可以直接移除或者排除​​Slf4j​​的依赖。具体方法取决于你的项目构建工具,比如Maven或Gradle。 使用Maven的排除依赖方法: 在你的​​pom.xml​​文件中,找到引入​​Slf4j​​的依赖项,添加排除依赖配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
xmlCopy code<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version><!-- 版本号 --></version>
    <exclusions>
        <exclusion>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
        </exclusion>
    </exclusions>
</dependency>

使用Gradle的排除依赖方法: 在你的​​build.gradle​​文件中,找到引入​​Slf4j​​的依赖项,添加排除依赖配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
groovyCopy codedependencies {
    implementation('org.slf4j:slf4j-log4j12:版本号') {
        exclude group: 'log4j', module: 'log4j'
    }
}
方法二:移除​​Log4j​​的依赖

如果你已经决定使用​​Slf4j​​作为日志框架,可以移除或者排除​​Log4j​​的依赖。 使用Maven的排除依赖方法: 在你的​​pom.xml​​文件中,找到引入​​Log4j​​的依赖项,添加排除依赖配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
xmlCopy code<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version><!-- 版本号 --></version>
    <exclusions>
        <exclusion>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
        </exclusion>
    </exclusions>
</dependency>

使用Gradle的排除依赖方法: 在你的​​build.gradle​​文件中,找到引入​​Log4j​​的依赖项,添加排除依赖配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
groovyCopy codedependencies {
    implementation('org.apache.logging.log4j:log4j-core:版本号') {
        exclude group: 'org.slf4j', module: 'slf4j-api'
    }
}

结论

在使用Java开发过程中,如果遇到​​java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path​​异常,可以考虑检查项目的依赖中是否存在​​Log4j​​和​​Slf4j​​这两个库的冲突。通过移除或排除其中一个库的依赖,可以解决这个问题。在选择移除或排除哪个库的依赖时,需要根据自己的项目需求和使用习惯来决定。希望本文对你解决这个问题有所帮助。

​log4j-over-slf4j.jar​​​和​​slf4j-log4j12.jar​​​是在使用​​SLF4J​​​(Simple Logging Facade for Java)和​​Log4j​​作为日志框架时常见的两个jar包。

  1. ​slf4j-log4j12.jar​​是​​SLF4J​​对​​Log4j 1.x​​的绑定实现。它实现了​​SLF4J​​的接口,并将日志消息转发给​​Log4j​​进行处理。通过使用​​slf4j-log4j12.jar​​,我们可以在使用​​SLF4J​​的代码中直接使用​​Log4j​​作为实际的日志框架。
  2. ​log4j-over-slf4j.jar​​则是反过来的,它是​​SLF4J​​对​​Log4j​​的一个桥接实现。它的作用是将原本使用​​Log4j​​的代码中的日志调用转发到​​SLF4J​​,然后再由​​SLF4J​​根据实际的配置绑定到具体的日志实现(比如​​Logback​​)上。 这两个jar包的存在是为了解决在使用​​SLF4J​​和​​Log4j​​组合时可能产生的冲突问题。​​SLF4J​​是一个轻量级的日志门面,它提供了统一的接口,可以方便地切换底层的日志实现。而​​Log4j​​是一个功能强大的日志框架,拥有丰富的配置选项和灵活的日志输出方式。 当我们使用​​SLF4J​​和​​Log4j​​组合时,可能会出现两个日志框架同时存在于项目中的情况。这样就会导致两个框架之间的冲突,引发一些问题,比如类冲突,导致​​java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path​​异常。 为了解决这个问题,我们可以选择使用​​slf4j-log4j12.jar​​来绑定​​Log4j 1.x​​,或者使用​​log4j-over-slf4j.jar​​来桥接其他日志实现,如​​Logback​​。通过选择适合的jar包,可以使我们的代码在使用统一的​​SLF4J​​接口的同时,能够正常地使用底层的日志实现。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

评论
登录后参与评论
暂无评论
推荐阅读
高质量前端快照方案:来自页面的「自拍」
将网页保存为图片(以下简称为快照),是用户记录和分享页面信息的有效手段,在各种兴趣测试和营销推广等形式的活动页面中尤为常见。
ConardLi
2019/12/19
2.9K0
高质量前端快照方案:来自页面的「自拍」
【Web技术】929- 前端海报生成的不同方案和优劣
首页测试demo:https://html2canvas.hertzen.com/
pingan8787
2021/04/26
1.6K0
【Web技术】929- 前端海报生成的不同方案和优劣
浅谈两种前端截图方式:Canvas截图 vs SVG截图
如今很多网站都引入截图功能,可用于问题反馈、内容分享等实用需求,而前端截图也不知不觉成为了首选。今天为大家推荐两种前端截图方式,虽然有些局限,但是也能应付大部分项目需求。
JowayYoung
2020/04/01
14.2K2
2种方式!带你快速实现前端截图
导语 | 本文将介绍在前端开发中页面截图的两种方式,包括对其实现原理和使用方式进行详细阐述,希望能为更多前端开发者提供一些经验和帮助。 一、 背景 页面截图功能在前端开发中,特别是营销场景相关的需求中, 是比较常见的。比如截屏分享,相对于普通的链接分享,截屏分享具有更丰富的展示、更多的信息承载等优势。最近在需求开发中遇到了相关的功能,所以调研了相关的实现和原理。 二、相关技术 前端要实现页面截图的功能,现在比较常见的方式是使用开源的截图npm库,一般使用比较多的npm库有以下两个: dom-to-image
腾讯云开发者
2022/03/03
4.4K1
【前端探索】移动端H5生成截图海报的探索
移动端H5生成图片海报分享,是比较常见的交互方式。生成的海报中,往往会有用户的个性化信息,比如头像、昵称等等。
luciozhang
2023/04/22
8240
# 浏览器截图方案分析
html2canvasopen in new window 用的比较广泛的前端截图方案,先将 DOM 一个个 转为 Canvas 然后导出图片(使用 canvas 自带的 toDataUrl、toBobl)即可。使用起来应该是兼容性比较好的方案了,能解决大部分的需求,但是也有一写小问题,如:
九旬
2023/10/19
5500
Vue 一键导出 PDF
生成 PDF 基本思路大多一致,先用 html2canvas 将 DOM 元素转换为 canvas,再利用 canvas 的 toDataURL 方法输出为图片,最后使用 jsPDF 添加图片生成 PDF 实现一键下载。
数媒派
2022/12/01
2K0
vue前端怎么导出图片_VUE中将页面导出为图片或者PDF
1.将页面html转换成图片 npm install html2canvas –save
全栈程序员站长
2022/09/01
2.8K0
Web动态图片合成与分享——html2canvas方案实践
在web侧运营活动中,分享传播是重要的一环。普通的h5链接/结构化消息分享已经不能满足产品越来越大的脑洞。在很多场景下,我们需要将个性化内容(如帐号信息,头像,用户输入等)固化为一张完整的图片,一秒分享到朋友圈&AIO&群,藉此提高传播效率。
WendyGrandOrder
2018/10/19
8.5K2
Web动态图片合成与分享——html2canvas方案实践
html2canvas - 项目中遇到的那些坑点汇总
因为css里的只是展示画布显示的大小,不像这样是canvas真正的内里图画分辨率的大小。
xing.org1^
2020/06/29
4.7K0
Vue页面生成分享海报最详说明(含二维码+多种水印方式+常见的坑处理)
解决办法: 如果使用的是uni-app中的image标签 需要替换为 img标签,image标签在uni-app中其实是背景图片
我只会写Bug啊
2023/12/25
7510
html2canvas图片模糊解决方案
页面采用ViewPort方案,解决iOS上的1px的边框问题,采用这个方案,在iOS上渲染出来的Dom会自动乘以devicePixelRatio,因此iOS上的Canvas相当于被直接放大了,没有出现模糊的情况。
xferris
2019/12/30
4.4K0
​html2canvas 出现图片无法展示
最近接收到一个优化需求:就是对之前的行程文档的图文介绍添加打印生成 pdf 的功能
公众号---人生代码
2020/11/26
2.5K0
使用 html2canvas 生成分享图片,CDN图片不展示问题
生成分享图片,包含后端返回的图文,图片是 cdn 资源。开始尝试使用 html2canvas 时,使用的是本地图片,生成截图无问题。
用户10106350
2022/10/28
2.2K0
页面DOM导出PDF
页面DOM导出PDF Nginx设置允许跨域 location /static { add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Credentials' 'true'; index index.html; root /data/wwwjarapi/8905xhkjfileapitest/; } 也就是在location下添加 add_header 'Access-Control-
码客说
2020/05/09
2.9K0
jscanvas合成图片实现微信公众号海报功能
在微信公众号开发中,很多时候都有个需求是一张图加上头像和昵称或者其他数据生成自己的二维码海报或者是生成分享海报
仙士可
2019/12/19
1.4K0
html2canvas实现浏览器截图的原理(包含源码分析的通用方法)
有时用户希望将我们的报表页面分享到其他的渠道,比如邮件、PPT等,每次都需要自己截图,一是很麻烦,二是截出来的图大小不一。
Kagol
2020/12/22
2.2K0
html2canvas实现浏览器截图的原理(包含源码分析的通用方法)
【架构师(第五十二篇)】 几个前端工具的基本使用
设备像素也被称为物理像素,是显示设备中一个最微小的物理部件,在同一设备中,物理像素的总数是固定的。
一尾流莺
2022/12/10
4220
Vue 结合html2canvas和jsPDF实现html页面转pdf
E:\MyProjects\TMP\frontend>npm install html2canvas
授客
2020/04/30
5K0
Vue 结合html2canvas和jsPDF实现html页面转pdf
JS - 原生js实现 网页截图(+下载截图) 功能
实现:html2canvas + canvas.toDataURL 首先,引入依赖插件: import { html2canvas } from './html2canvas'; html2canvas截图模糊处理: 1 /*图片跨域及截图模糊处理*/ 2 let canvasContent = document.getElementById('canvas'),//需要截图的包裹的(原生的)DOM 对象 3 width = canvasContent.clientWidth,//canvas
xing.org1^
2018/05/17
30.5K1
推荐阅读
相关推荐
高质量前端快照方案:来自页面的「自拍」
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验