導航:首頁 > 凈水問答 > log4j過濾日誌敏感信息

log4j過濾日誌敏感信息

發布時間:2023-11-15 14:43:31

① Slf4j + Logback 怎麼過濾掉第三方包中的日誌顯示

其實這跟 Slf4J 通用日誌框架沒什麼關系,單單是 Logback 的事,把 Slf4J 扯進來只因它們是對黃金組合。
我們在 log4j 中想要不顯示第三方包的非常冗餘的日誌輸出時,只要在 log4j.properties 中寫上:

1

log4j.logger.org.hibernate=ERROR

這樣在 hibernate 里的日誌級別在 ERROR 以下的 TRACE、DEBUG、WARN 和 INFO 將不被輸出,控制台會比較的干凈。
Logback 的配置文件是 logback.xml,曾經在裡面給 <appender> 加的 <pattern> 是:

1

<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>

logger 名顯示 35 字元,類名優先顯示全,類全限名超過總長度則取前面若干包名的首字母連接起來,於是產生了像下面那樣的日誌輸出:
7937 [main] DEBUG o.s.b.f.s.DefaultListableBeanFactory - Returning cached instance of singleton
7781 [main] DEBUG o.h.loader.entity.EntityLoader - Static select for entity
這在 Log4J 中是未曾見過的。當時還以為日誌名就是 o.s.b.f 這樣的東西,於是在 logback.xml 中用

1
2

<logger name="o.s.b" level="WARN"/>
<logger name="o.h" level="WARN"/>

這樣的代碼來進行封鎖,根本就無濟於事,大量的 spring、hibernate 的 DEBUG、INFO 等日誌照樣輸出。這時惦記起 Logback 的 filter 功能來了,配置上:

01
02
03
04
05
06
07
08
09
10
11

<filter>
<evaluator> <!-- defaults to type ch.qos.logback.classic.boolex.JaninoEventEvaluator -->
<expression><![CDATA[
event.getThreadName().contains("Catalina")
|| event.getLoggerName().contains("o.s.b.f")
|| event.getLoggerName().contains("o.h.")
]]></expression>
</evaluator>
<OnMismatch>NEUTRAL</OnMismatch>
<OnMatch>DENY</OnMatch>
</filter>

也是沒有效果的。想來 Logback 與 Log4J 相比不會這么差勁的,再怎麼也是出自一人之手,想來思路應是一致的,還是該回到 <logger> 的配置上來。
還是 Google 威武,找到答案了:logback per-logger configuration is not working。原來像 "o.s.b.f" 和 "o.h." 這樣的東西只是神馬浮雲,假象而已,它們實際所代表的 logger 名並未變,分別是:
org.springframework.beans.factory.support.DefaultListableBeanFactory
org.hibernate.loader.entity.EntityLoader
所以呢,在 logback.xml 中像 Log4J 一樣寫上

1
2

<logger name="org.hibernate" level="WARN"/>
<logger name="org.springframework" level="WARN"/>

就把 Spring 和 Hibernate 的日誌輸出稍加過濾了,都是 %logger{35} 中的那個 {35} 惹的禍,不過也靠它多了解了一點東西。如果只寫成 %logger 話那時候當然可以很快的解決問題的。

閱讀全文

與log4j過濾日誌敏感信息相關的資料

熱點內容
污水廠操作工安全生產 瀏覽:452
廢水檢測裝置 瀏覽:436
空氣濾芯製作什麼東西 瀏覽:599
樹脂標號什麼意思 瀏覽:600
甜米酒發酵好要不要蒸餾 瀏覽:622
安利車載空氣凈化器怎麼樣 瀏覽:943
寶寶不吃奶頭用吸奶器吸會回奶么 瀏覽:867
垃圾填埋廠的反滲透裝置 瀏覽:12
凈水器使用前先要放掉多少水 瀏覽:160
水泵房上方有污水管 瀏覽:623
武昌凈水神器怎麼樣 瀏覽:22
生產空氣凈化器企業屬於什麼行業 瀏覽:65
開封污水處理廠項目中標 瀏覽:796
350w小型凈化器多少錢 瀏覽:693
宏森污水處理 瀏覽:68
污水提升器廠家推薦 瀏覽:444
沁園185e凈水機濾芯怎麼安裝 瀏覽:291
污水水解酸化池加什麼葯劑 瀏覽:565
自流平地面和環氧樹脂 瀏覽:801
本田思域拆機油濾芯用什麼扳手 瀏覽:286