SLF4J(Simple Logging Facade for Jave).

上个章节在配置启动项目后,会报一个奇怪的错误,一开始以为是Maven 依赖有冲突,其实是和slf4j 密切相关的。

本文原链接地址http://www.cnblogs.com/bnbqian/

46.1 最常见的Error Message

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
  SLF4J: Defaulting to no-operation (NOP) logger implementation
  SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
这个错误其实再明显不过了,就是说在当前class path 下找不到 slf4j 的binding.
至于binding 是什么,和slf4j 是什么关系,这个就要从这个应用的定位开始说起。

46.2 slf4j 究竟是什么

slf4j 的f 的含义就是外观或者说是一种抽象,这就对了,slf4j 是对各种各样主流log 框架的一个抽象接口。

比如说 java.util.logging, logback, log4j.

slf4j 其实只有一个jar 包,那就是 slf4j-api-1.7.5.jar.

自从1.6.0 版本开始,如果么有找到对应的绑定,slf4j 将会默认转向无操作的实现,也就是不输出任何log.

46.3 slf4j 的binding 究竟是什么

就像上面所说的,slf4j 只是接口,能够支持各种log 框架的工作。但是slf4j 和log 框架之间,需要一个类似与转换器一样的东西。

slf4j 和每一个log 框架的整合都是通过这个转换器的。

例如:

slf4j-log4j12-1.7.5.jar 就是一个连接log4j.jar 的binding

slf4j-jdk14-1.7.5 就是一个连接JDK1.4 logging 的binding

slf4j-simple-1.7.5.jar 简单的将日志输出到System.err, 适合小程序的binding

slf4j-nop-1.7.5.jar 这个东东就是啥都不做

只要通过替换这个binding 就可以直接替换对应的日志框架,自然就happy了。

46.4 日志框架开发应该依赖slf4j-api, 而不该依赖binding

这个是显而易见的,slf4j 设计的目的就是可以随时随地切换日志组件,任何框架都不该依赖于binding.

也就是这个原因,在Maven 中添加了Hibernate-core 后,并不会下载对应的binding.

以至于程序刚开始的时候会有个简单的信息告诉我们日志模块被切到了nop.

46.5 Log4j

我们的项目已经添加了log4j 的 jar 包,接下去自然加上对应的binding 就可以了。

折腾了好久,中央仓库可能暂时升天了,找替换仓库。

<repositories>
        <repository>
            <id>central</id>
            <name>replace</name>
            <url>http://mirrors.ibiblio.org/maven2/</url>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
        </repository>

加上binding

<dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.2</version>
        </dependency>

日志终于能够正常输出了!

有些时候不要去中央仓库下载jar 包了,手动安装jar 包到本地仓库的技能我觉得也是必须的。

手动安装目前暂时不需要了,先标记个参考文章吧,下次可以阅读 http://www.blogjava.net/fancydeepin/archive/2012/06/12/380605.html 说白了其实就是下载包,然后一个命令行,今天的时间结束。

Java Hour 46 SLF4J的更多相关文章

  1. 纯Java配置使用slf4j配置log4j

    工程目录如下 代码里面用的是slf4j,但是想要用log4j来管理日志,就得添加slf4j本来的jar,然后添加log4j和slf4j箱关联的jar即可. 如果是maven项目的话添加下面的依赖即可 ...

  2. java日志框架slf4j与log4j

    日志记录自然是非常重要的,但恐怕能记住slf4j与log4j等日志框架配置的人就很少了,这个东西不难,只是配置好后很少会去动它,开发新项目一般也是从其他项目拷贝,或者参照文档 废话不多说,先说log4 ...

  3. Java日志框架Slf4j+Log4j入门

    一.日志系统介绍 slf4j,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统.简答的讲就是slf4j是一系列的日志 ...

  4. java日志-纯Java配置使用slf4j配置log4j(转)

    工程目录如下 代码里面用的是slf4j,但是想要用log4j来管理日志,就得添加slf4j本来的jar,然后添加log4j和slf4j箱关联的jar即可. 如果是maven项目的话添加下面的依赖即可 ...

  5. java日志之slf4j与logback简单使用

    最近在开发遇到日志是使用slf4j与logback.xml的配置,所以就记录下来了. 1.导入这几个jar包: Logback 分为三个模块:logback-core,logback-classic, ...

  6. Java日志:集成slf4j和logback

    Java日志方案有很多,包括:java.util.logging.Apache的commons-logging和log4j.slf4j以及logback. 一个大型项目会用到众多第三方jar包,这些j ...

  7. Java日志之Slf4j,Log4J,logback原理总结

    几乎任何应用,一定是需要日志的. 那么,面对种类繁多的日志框架和配置,我们该何去何从? 1.前奏:我是在研究mybatis源码的过程中才意识到需要搞明白日志原理这回事,因为mybatis(和一些其他开 ...

  8. Java日志框架SLF4J和log4j以及logback的联系和区别

    1.SLF4J(Simple logging Facade for Java) 意思为简单日志门面,它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接 ...

  9. Java日志使用slf4j 配置log4j后,有日志文件 但日志文件内容为空

    SLF4J的全称是Simple Logging Facade for Java,即简单日志门面. SLF4J并不是具体的日志框架,而是作为一个简单门面服务于各类日志框架,如java.util.logg ...

随机推荐

  1. ajax 如何做到 SEO 友好

    我猜你是在网络上搜索“ajax如何被搜索引擎收录”.“ajax SEO”.“ajax SEO友好”等关键词来到这里的.你可能已经很疲惫了,因为前段时间我也这样搜索,但是我发现搜索到的内容质量不高,有的 ...

  2. c++强制类型转换:dynamic_cast、const_cast 、static_cast、reinterpret_cast

    c++强制类型转换:dynamic_cast.const_cast .static_cast.reinterpret_cast 博客分类: C/C++ CC++C#编程数据结构  dynamic_ca ...

  3. LR测试心得

    ====================测试方案—优化前—优化后 每一项至少两份报告==================================== url录制方式录制出来的脚本mode是HT ...

  4. [Effective JavaScript 笔记]第55条:接收关键字参数的选项对象

    53节建议保持参数顺序的一致约定对于帮助程序员记住每个参数在函数调用中的意义很重要.参数较少这个主意不错,但如果参数过多后,就出现麻烦了,记忆和理解起来都不太容易. 参数蔓延 如下面这些代码: var ...

  5. Unity3D研究之Prefab里面的Prefab关联问题

    Unity研究院之Prefab和GameObject的正向和逆向查找引用 我发现很多美工兄弟都爱问程序Unity3d为什么总丢材质? 我不排除U3d有BUG的情况下会丢材质?但是其实很多时候是人为操作 ...

  6. xcode6以后, 使用.pch

    http://blog.csdn.net/lihuiqwertyuiop/article/details/39268101 总结: . 创建.pch文件 . Apple LLVM 6.1 - Lang ...

  7. 如何用rake tasks 生成migration对应的sql

    how-to-use-rake-tasks-to-generate-migration-sql Rakefile文件里有load_tasks的方法 http://api.rubyonrails.org ...

  8. ubuntu下git输出的颜色变化

    (这些文章都是从我的个人主页上粘贴过来的,大家也可以访问我的主页 www.iwangzheng.com) 11点进家门,感觉很温暖哦. 以下是如何在用git的时候清晰的看出关键字的方法. $ vim ...

  9. 他们在军训,我在搞OI(三)

    昨天忘记写了,因为急着去看 51nod 比赛,然而思考了许久还是一道都不会,好菜啊T_T... 补一下 Day 3 的情况. Day 3 上午还是常规地做 vjudge 上的套题,硬着头皮啃英文,感觉 ...

  10. 配置oss bucket cors

    到bucket中属性中选择跨越设置,点击添加规则会看到以下界面: 对应的输入如上即可.