亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解SSM框架下結(jié)合log4j、slf4j打印日志

 更新時(shí)間:2017年11月28日 17:12:12   作者:javaobject  
本篇文章主要介紹了詳解SSM框架下結(jié)合log4j、slf4j打印日志,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

本文主要介紹了詳解SSM框架下結(jié)合log4j、slf4j打印日志,分享給大家,具體如下:

首先加入log4j和slf4j的jar包

 <!-- 日志處理 
   <!-- slf4j日志包-->
   <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.21</version>
   </dependency>
   <dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.21</version> 
   </dependency>
   <!-- 引入log4j日志包-->
   <dependency>
   <groupId>log4j</groupId> -->
   <artifactId>log4j</artifactId> 
   <version>1.2.16</version>
   </dependency> 

Mybatis內(nèi)置的日志工廠提供日志功能,具體的日志實(shí)現(xiàn)有以下幾種工具:

  1. SLF4J
  2. Apache Commons Logging
  3. Log4j 2
  4. Log4j
  5. JDK logging

1、具體選擇哪個(gè)日志實(shí)現(xiàn)工具由MyBatis的內(nèi)置日志工廠確定。它會(huì)使用最先找到的(按上文列舉的順序查找)。 如果一個(gè)都未找到,日志功能就會(huì)被禁用。

不少應(yīng)用服務(wù)器的classpath中已經(jīng)包含Commons Logging,如Tomcat和WebShpere, 所以MyBatis會(huì)把它作為具體的日志實(shí)現(xiàn)。記住這點(diǎn)非常重要。這將意味著,在諸如 WebSphere的環(huán)境中——WebSphere提供了Commons Logging的私有實(shí)現(xiàn),你的Log4J配置將被忽略。 這種做法不免讓人悲催,MyBatis怎么能忽略你的配置呢?事實(shí)上,因Commons Logging已經(jīng)存 在了,按照優(yōu)先級(jí)順序,Log4J自然就被忽略了!不過,如果你的應(yīng)用部署在一個(gè)包含Commons Logging的環(huán)境, 而你又想用其他的日志框架,你可以通過在MyBatis的配置文件mybatis-config.xml里面添加一項(xiàng)setting(配置)來選擇一個(gè)不同的日志實(shí)現(xiàn)。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

 <!-- 用于輸出日志 log4j:LOG4J SLF4J -->
 <settings> 
  <setting name="logImpl" value="SLF4J"/> 
 </settings> 

 <!-- 此文件可以為空文件, 但是必須要有這文件 -->
 
 <!-- plugins在配置文件中的位置必須符合要求,否則會(huì)報(bào)錯(cuò),順序如下: properties?, settings?, typeAliases?, 
  typeHandlers?, objectFactory?,objectWrapperFactory?, plugins?, environments?, 
  databaseIdProvider?, mappers? -->
 <plugins>
  <!-- com.github.pagehelper為PageHelper類所在包名 -->
  <plugin interceptor="com.github.pagehelper.PageHelper">
   <!-- 4.0.0以后版本可以不設(shè)置該參數(shù) -->
   <property name="dialect" value="mysql" />
   <!-- 該參數(shù)默認(rèn)為false -->
   <!-- 設(shè)置為true時(shí),會(huì)將RowBounds第一個(gè)參數(shù)offset當(dāng)成pageNum頁(yè)碼使用 -->
   <!-- 和startPage中的pageNum效果一樣 -->
   <property name="offsetAsPageNum" value="true" />
   <!-- 該參數(shù)默認(rèn)為false -->
   <!-- 設(shè)置為true時(shí),使用RowBounds分頁(yè)會(huì)進(jìn)行count查詢 -->
   <property name="rowBoundsWithCount" value="true" />
   <!-- 設(shè)置為true時(shí),如果pageSize=0或者RowBounds.limit = 0就會(huì)查詢出全部的結(jié)果 -->
   <!-- (相當(dāng)于沒有執(zhí)行分頁(yè)查詢,但是返回結(jié)果仍然是Page類型) -->
   <property name="pageSizeZero" value="true" />
   <!-- 3.3.0版本可用 - 分頁(yè)參數(shù)合理化,默認(rèn)false禁用 -->
   <!-- 啟用合理化時(shí),如果pageNum<1會(huì)查詢第一頁(yè),如果pageNum>pages會(huì)查詢最后一頁(yè) -->
   <!-- 禁用合理化時(shí),如果pageNum<1或pageNum>pages會(huì)返回空數(shù)據(jù) -->
<!--    <property name="reasonable" value="false" /> -->
   <!-- 3.5.0版本可用 - 為了支持startPage(Object params)方法 -->
   <!-- 增加了一個(gè)`params`參數(shù)來配置參數(shù)映射,用于從Map或ServletRequest中取值 -->
   <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,orderBy,不配置映射的用默認(rèn)值 -->
   <!-- 不理解該含義的前提下,不要隨便復(fù)制該配置 -->
<!--    <property name="params" value="pageNum=pageHelperStart;pageSize=pageHelperRows;" /> -->
   <!-- 支持通過Mapper接口參數(shù)來傳遞分頁(yè)參數(shù) -->
   <property name="supportMethodsArguments" value="false" />
   <!-- always總是返回PageInfo類型,check檢查返回類型是否為PageInfo,none返回Page -->
   <property name="returnPageInfo" value="none" />
  </plugin>
 </plugins>
 
</configuration> 

logImpl可選的值有:SLF4J、LOG4J、LOG4J2、JDK_LOGGING、COMMONS_LOGGING、STDOUT_LOGGING、NO_LOGGING 或者是實(shí)現(xiàn)了接口org.apache.ibatis.logging.Log的類的完全限定類名, 并且這個(gè)類的構(gòu)造函數(shù)需要是以一個(gè)字符串(String類型)為參數(shù)的。 (可以參考o(jì)rg.apache.ibatis.logging.slf4j.Slf4jImpl.java的實(shí)現(xiàn))

你根據(jù)需要調(diào)用如下的某一方法:

org.apache.ibatis.logging.LogFactory.useSlf4jLogging();
org.apache.ibatis.logging.LogFactory.useLog4JLogging();
org.apache.ibatis.logging.LogFactory.useJdkLogging();
org.apache.ibatis.logging.LogFactory.useCommonsLogging();
org.apache.ibatis.logging.LogFactory.useStdOutLogging();

如果的確需要調(diào)用以上的某個(gè)方法,請(qǐng)?jiān)谄渌蠱yBatis方法之前調(diào)用它。另外,只有在相應(yīng)日志實(shí)現(xiàn)中存在 的前提下,調(diào)用對(duì)應(yīng)的方法才是有意義的,否則MyBatis一概忽略。如你環(huán)境中并不存在Log4J,你卻調(diào)用了 相應(yīng)的方法,MyBatis就會(huì)忽略這一調(diào)用,代之默認(rèn)的查找順序查找日志實(shí)現(xiàn)。

2、配置web.xml

<!-- 加載log4j -->
 <context-param>
  <param-name>log4jConfigLocation</param-name>
  <param-value>classpath:log4j.properties</param-value>
 </context-param>
 <listener>
  <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
 </listener>

3、只要在應(yīng)用的classpath中創(chuàng)建一個(gè)名稱為log4j.properties的文件, 文件的具體內(nèi)容如下:

log4j.rootLogger=INFO,console,dailyFile
# TODO 發(fā)布到阿里云記得添加,另外控制臺(tái)不輸出(只輸出warn或者error信息)
#INFO,console,dailyFile

log4j.logger.org.mybatis =DEBUG
log4j.logger.com.itzixi.mapper=DEBUG

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.encoding=UTF-8
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%l] - [%p] %m%n
#mybatis顯示SQL語句日志配置 
#log4j.logger.org.mybatis=DEBUG
#log4j.logger.com.itzixi.mapper=DEBUG 

# 定期滾動(dòng)日志文件,每天都會(huì)生成日志
log4j.appender.dailyFile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.dailyFile.encoding=UTF-8
log4j.appender.dailyFile.Threshold=INFO
# TODO 本地日志地址,正式環(huán)境請(qǐng)務(wù)必切換為阿里云地址
#log4j.appender.dailyFile.File=C:/logs/itzixi-web/log.log4j
log4j.appender.dailyFile.File=/itzixi-disk1/logs/itzixi-web/log.log4j
log4j.appender.dailyFile.DatePattern='.'yyyy-MM-dd
log4j.appender.dailyFile.layout=org.apache.log4j.PatternLayout
log4j.appender.dailyFile.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%l] - [%p] %m%n


##顯示SQL語句部分
#log4j.logger.com.ibatis=DEBUG
#log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG
#log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG
#log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
#log4j.logger.java.sql.Connection=DEBUG
#log4j.logger.java.sql.Statement=DEBUG
#log4j.logger.java.sql.PreparedStatement=DEBUG

如圖當(dāng)我們?cè)谶\(yùn)行進(jìn)入debug時(shí)就有sql語句打印了

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • java之構(gòu)造器的重載問題

    java之構(gòu)造器的重載問題

    這篇文章主要介紹了java之構(gòu)造器的重載問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • java實(shí)現(xiàn)sftp客戶端上傳文件以及文件夾的功能代碼

    java實(shí)現(xiàn)sftp客戶端上傳文件以及文件夾的功能代碼

    本篇文章主要介紹了java實(shí)現(xiàn)sftp客戶端上傳文件以及文件夾的功能代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。
    2017-02-02
  • mybatis-plus邏輯刪除與唯一約束沖突問題

    mybatis-plus邏輯刪除與唯一約束沖突問題

    本文探討了MyBatis-Plus邏輯刪除與唯一約束沖突的問題,分析了產(chǎn)生沖突的原因,并提出了解決方案,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-11-11
  • 解析spring boot與ireport 整合問題

    解析spring boot與ireport 整合問題

    本文通過實(shí)例代碼給大家介紹了spring boot 與 ireport 整合問題,關(guān)于pom文件依賴的問題通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-10-10
  • java 獲取字節(jié)碼文件的幾種方法總結(jié)

    java 獲取字節(jié)碼文件的幾種方法總結(jié)

    這篇文章主要介紹了java 獲取字節(jié)碼文件的幾種方法總結(jié)的相關(guān)資料,這里總結(jié)了三種方法幫助大家實(shí)現(xiàn)該功能,需要的朋友可以參考下
    2017-08-08
  • Java中Collections.sort的使用

    Java中Collections.sort的使用

    本文主要介紹了Java中Collections.sort的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Java如何實(shí)現(xiàn)多個(gè)線程之間共享數(shù)據(jù)

    Java如何實(shí)現(xiàn)多個(gè)線程之間共享數(shù)據(jù)

    這篇文章主要介紹了Java如何實(shí)現(xiàn)多個(gè)線程之間共享數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Nacos框架與原理之Nacos的參數(shù)

    Nacos框架與原理之Nacos的參數(shù)

    這篇文章主要介紹了Nacos框架與原理之Nacos的參數(shù),Nacos?中的參數(shù)有很多,如:命名空間、分組名、服務(wù)名、保護(hù)閾值、服務(wù)路由類型、臨時(shí)實(shí)例等,但下面文章我們要講解的是參數(shù),參數(shù)是什么呢,下面一起進(jìn)去文章學(xué)習(xí)詳細(xì)內(nèi)容吧
    2022-05-05
  • 2024版本IDEA創(chuàng)建Servlet模板的圖文教程

    2024版本IDEA創(chuàng)建Servlet模板的圖文教程

    新版IDEA?2024.1.4中,用戶需要自行創(chuàng)建Servlet模板以解決Web項(xiàng)目無法通過右鍵創(chuàng)建Servlet的問題,本文詳細(xì)介紹了添加ServletAnnotatedClass.java模板的步驟,幫助用戶快速配置并使用新的Servlet模板,需要的朋友可以參考下
    2024-10-10
  • 走進(jìn)JDK之不可變類String

    走進(jìn)JDK之不可變類String

    這篇文章主要給大家介紹了JDK之不可變類String的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JDK具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論