使用Spring配置LogBack日志記錄

LogBack是由Log4j的同一作者創建的用于記錄日志的API(較新的實現,它類似于新版本),在本文中,我將展示如何在Spring項目中對其進行集成和使用。

在本教程中,我假設您正在使用一個簡單的Spring ROO項目,該項目將為您準備項目的所有結構,有關更多信息,請參見: http : //www.springsource.org/spring-roo 。

首先,您需要在src / main / resources中創建logback.xml (保存配置附加程序,如log4j.properprties):


<?xml version="1.0" encoding="UTF-8"?><configuration><appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d %5p | %t | %-55logger{55} | %m %n</pattern></encoder></appender><logger name="test.myapp.repos"><level value="INFO" /></logger><logger name="org.springframework"><level value="INFO" /></logger><root><level value="INFO" /><appender-ref ref="CONSOLE" /></root></configuration>

第二步是配置Maven依賴項并添加LogBack所需的庫:

<-- Properties Settings --><properties><roo.version>1.1.0.RELEASE</roo.version><spring.version>3.0.5.RELEASE</spring.version><aspectj.version>1.6.10</aspectj.version><slf4j.version>1.6.1</slf4j.version><logback.version>0.9.26</logback.version><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><-- Dependencies Settings --><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>${slf4j.version}</version></dependency><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.16</version></dependency><dependency><groupId>org.slf4j</groupId><artifactId>jcl-over-slf4j</artifactId><version>${slf4j.version}</version></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>${logback.version}</version></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-core</artifactId><version>${logback.version}</version></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-access</artifactId><version>${logback.version}</version></dependency>

您需要擺脫由Spring ROO生成的Maven pom.xml中的所有Log4j依賴關系,在添加提供的用于設置LogBack的代碼之前,清除與日志記錄相關的每個依賴關系。

為了在正在開發的類上使用記錄器,您需要創建它的靜態實例并在使用Log4J時正常使用,唯一的區別是LogBack與Log4j的實現和配置代碼。 在Logback.xml上,必須掃描您的類以使記錄器正常工作。

package test.myapp.repos; /*This package figures on LogBack.xml*/import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class MyTestClass {static Logger logger = LoggerFactory.getLogger(ItemController.class);...public void create(String args) {logger.debug("My Args Is => " + args);}...}
還有另一種將記錄器注入Spring Bean的復雜方法,這可以通過開發自定義BeanPostProcessor來實現,該方法將自動將Logger注入帶有@Log的字段(這是我們創建的自定義注釋),而不是手動實例化如前所述的記錄器。
/** Custom @Logger annotation **/@Retention(RUNTIME)@Target(FIELD)@Documentedpublic @interface Log { }/** LoggerPostProcessor => Custom Spring BeanPostProcessor **/public class LoggerPostProcessor implements BeanPostProcessor {public Object postProcessAfterInitialization(Object bean, String beanName) throwsBeansException {return bean;}public Object postProcessBeforeInitialization(final Object bean, String beanName)throws BeansException {ReflectionUtils.doWithFields(bean.getClass(), new FieldCallback() {@SuppressWarnings("unchecked")public void doWith(Field field) throws IllegalArgumentException,IllegalAccessException {ReflectionUtils.makeAccessible(field);//Check if the field is annoted with @Logif (field.getAnnotation(Log.class) != null) {Log logAnnotation = field.getAnnotation(Log.class);Logger logger = LoggerFactory.getLogger(bean.getClass());field.set(bean, logger);}}});return bean;}}/** Usage on a Spring Bean **/@Componentpublic class MyBeanImpl implements MyBean {/** Not manual set up code **/@Log Logger myLogger;...}

最后要做的是在您的applicationContext.xml文件中聲明這個新的BeanPostProcessor:

<!-- The Logger Injector --><bean id="LogginInjector" class="ma.oncf.achat.utils.LoggerPostProcessor" />

有關為什么切換到LogBack的更多信息,請參閱: 為什么切換到LogBack 。

參考:來自Fancy UI博客的JCG合作伙伴 Idriss Mrabti使用Spring配置LogBack Logging 。

相關文章 :

  • Spring 3.1和Hibernate的持久層
  • 使用Spring和Java泛型簡化數據訪問層
  • Spring陷阱:事務測試被認為是有害的
  • Log4j,Stat4j,SMTPAppender集成–匯總錯誤日志以發送太多電子郵件
  • Java日志混亂
  • 正確記錄應用程序的10個技巧
  • 首先記錄異常的根本原因

翻譯自: https://www.javacodegeeks.com/2011/12/configure-logback-logging-with-spring.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/374286.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/374286.shtml
英文地址,請注明出處:http://en.pswp.cn/news/374286.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

自定義URL Scheme完全指南

iPhone / iOS SDK 最酷的特性之一就是應用將其自身”綁定”到一個自定義 URL scheme 上&#xff0c;該 scheme 用于從瀏覽器或其他應用中啟動本應用。 注冊自定義 URL Scheme 注冊自定義 URL Scheme 的第一步是創建 URL Scheme — 在 Xcode Project Navigator 中找到并點擊工程…

C學習雜記(五)形參實參筆試題

大意失荊州 不要以為簡單就輕視&#xff0c;謹慎&#xff0c;細節&#xff0c;基礎。 一、有以下程序 #include <stdio.h>typedef struct {int b, p;} A;void f(A c) {c.b 1; c.p 2; }void main(void) {A a {1, 2};f(a);printf("%d, %d\n", a.b, a.p); } …

avframe轉byte數組_C# amp; VB6.0 圖像與二維數組 互轉

背景最近在研究C#進行圖像處理&#xff0c;在圖像處理中算法中&#xff0c;往往都是針對的是矩陣運算的。矩陣其實就是一個二維的數組。為了圖像處理的速度&#xff0c;我們都需要放在內存中處理。但網絡上收集的代碼&#xff0c;往往都是以一維數組的樣子提供結果&#xff0c;…

C學習雜記(六)%2.0f打印輸出寬度

%m.nf&#xff0c;m表示整個浮點數的輸出寬度&#xff0c;n表示小數輸出寬度。 1、printf("%f\n", 12.34); 輸出為12.340000。 2、printf("%2.0f\n", 12.34); 輸出為12。 3、printf("%2.1f\n", 12.34); 輸出為12.3。 4、printf(&qu…

P6 音頻格式—— AAC

目錄 前言 01 AAC是什么&#xff1f; 02 為什么需要進行AAC進行音頻壓縮處理&#xff1f; 03 AAC的特點以及優勢 04 AAC格式詳解&#xff1a; 4.1. ADIF的數據結構&#xff1a; 4.1.1 ADIF Header具體的表格: 4.2. ADTS的結構&#xff08;重點&#xff09;&#xff1a; …

Android開發筆記——ListView模塊、緩存及性能

ListView是Android開發中最常用的組件之一。本文將重點說明如何正確使用ListView&#xff0c;以及使用過程中可能遇到的問題。 ListView開發模塊圖片緩存可能遇到的問題一、ListView開發模塊 從項目實踐的角度來看&#xff0c;ListView適合“自底向上”的開發模式&#xff0c;即…

python實現excel篩選功能并輸出_python如何實現excel按顏色篩選功能

離島 2020-07-09 09:37 已采納 不太了解具體需求&#xff0c;提供一些示例代碼和思路供你參考&#xff1a; 整體思路&#xff1a;首先已知excel中的顏色值&#xff0c;根據編碼實現顏色篩選的功能 示例&#xff1a; 1、首先安裝pip install openpyxl 2、示例代碼可以獲取Excel中…

什么是CDI,它與@EJB和Spring有什么關系?

簡要概述了Java EE中的依賴項注入&#xff0c; Resource / EJB和Inject之間的區別以及它們與Spring的關系-主要是鏈接形式。 上下文依賴注入&#xff08;CDI&#xff0c; JSR 299 &#xff09;是Java EE 6 Web Profile的一部分&#xff0c;它本身基于Java依賴注入&#xff08;…

C學習雜記(七)extern聲明可省略變量類型

工作三年&#xff0c;看C的書也不少。第一次知道extern可以省略變量類型。 b.c有一個全局變量unsigned int data_length&#xff0c;a.c想要調用它&#xff0c;通常使用: extern unsigned int data_length&#xff1b; 在聲明時可以把外部變量類型去掉&#xff1a;extern da…

KMP模板

1 ///KMP模板2 ///生成next數組3 void get_next()4 {5 int i0,j-1;6 next[0]-1;7 while (s1[i])8 {9 if (j-1||s1[i]s1[j]) 10 { 11 i; 12 j; 13 next[i]j; 14 } 15 else jnext[j]; 16 …

使用Apache CXF進行Web服務學習

在我的最后幾個項目中&#xff0c;我使用了Web服務&#xff0c;在某些地方創建它們并在其他地方使用它們。 我覺得創建客戶端&#xff0c;創建Web服務等標準任務非常簡單&#xff0c;如果遇到問題&#xff0c;有足夠的資源。 但是對于Web服務&#xff0c;這是一項瑣碎的任務&am…

python的easygui_Python的easygui學習

1.調用方法 &#xff08;1&#xff09;import easygui easygui.msgbox(…) &#xff08;2&#xff09;from easygui import msgbox(…) 2.函數方法 import easygui a easygui.msgbox(’…’, title‘title’) # show a:返回ok,none b easygui.enterbox( ‘plaese give a solu…

c#遞歸

一種算法&#xff0c;通過簡潔的語句定義無限集合、函數或者子程序在運行時直接或間接調用自身產生重入的現象。 特點&#xff1a;遞歸算法分遞推&#xff08;簡單到復雜的推理過程&#xff09;和回歸&#xff08;獲得簡單解后逐級返回得到復雜的解&#xff09;2個階段。 可理解…

HDU5724

題意&#xff1a; 一個 n * 20 的棋盤&#xff0c;棋盤上有若干棋子&#xff0c;Alice 和 Bob 輪流走&#xff0c;每人每次可以選擇任一行的一顆棋子向右移動到最近的一個空格 &#xff1b;也就是說如果右邊與它相鄰的格子里沒有棋子&#xff0c;就移到右邊與他相鄰的格子去&am…

C語言代碼規范(九)運算符優先級使用括號提高閱讀性

舉簡單例子 a b | c << d 2; 對于大牛沒有問題&#xff0c;對于我這樣的碼農需要思考一下運算優先級 對于這種情況華某有規范使用括號來表示運算順序&#xff0c;從而提高代碼可閱讀性 a b | ( c << (d 2) ); 這樣一目了然&#xff0c;大家好才是真的好。…

linux 內存取證_【取證流程】電子數據證據遠程勘驗

原創&#xff1a;弘連網絡電子數據證據遠程勘驗在日常的取證工作中必不可少&#xff0c;但由于存在信息安全差、數據可能被篡改的問題。取證過程中&#xff0c;有明確的取證要求來確保取證過程的規范顯得至關重要&#xff0c;今天我們就一起來回顧下遇到遠程勘驗的取證場景&…

OSGi –帶有服務的簡單Hello World

在本文中&#xff0c;我們將使用OSGi開發一個簡單的Hello World應用程序。 我們將使用Felix作為OSGi容器 。 在下一篇文章中&#xff0c;我們將繼續使用該應用程序&#xff0c;并使用Spring Dynamic Modules對其進行改進。 為了使開發有趣&#xff0c;我們將創建兩個捆綁包&…

Shell - 特殊變量

$0 表示所執行程序的路徑名。 [hueyhuey-K42JE ~]$ ll ~/bin total 4 -rwxrwxr-x 1 huey huey 21 Oct 24 14:39 hello [hueyhuey-K42JE ~]$ cat ~/bin/hello #!/bin/bashecho $0: $0 [hueyhuey-K42JE ~]$ hello /home/huey/bin/hello [hueyhuey-K42JE ~]$ $n 表示傳遞給腳本…

jquery技巧

返回頂部按鈕 利用 jQuery 中的 animate 和 scrollTop 方法&#xff0c;你無需插件就可以創建簡單的 scroll up 效果: // 返回頂部 $(a.top).click(function (e) { e.preventDefault();//ff下阻止滾動條默認行為 $(document.body).animate({scrollTop: 0}, 800); }); <a cla…

串口不通或亂碼,排查方法

硬件問題&#xff1a; 1、USB轉串口工具有問題&#xff0c;換一個工具試試&#xff08;用久了很容易壞的東西&#xff09; 2、外部晶振有問題 3、單片機和外設的TX、RX連接電路上是否增加了元器件&#xff1f;比如0歐姆電阻。去掉以后是否能通&#xff1f;&#xff08;遇到過一…