成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

基于 log4j2 插件實現統一日志脫敏,性能遠超正則替換

開發 前端
我們可以基于 log4j2 RewritePolicy 統一使用脫敏策略。本項目自 V1.2.0 添加對應支持,后續將提升對應的可拓展性。

前言

金融用戶敏感數據如何優雅地實現脫敏?

日志脫敏之后,無法根據信息快速定位怎么辦?

經過了這兩篇文章之后,我們對日志脫敏應該有了一定的理解。

但是實際項目中,我們遇到的情況往往更加復雜:

  • 項目的 java bean 定義不規范,大量接口使用 map。
  • 歷史項目眾多,改造成本巨大。

種種原因,導致使用注解的方式耗費大量的時間。但是一般給我們改造的時間是有限的。

那么,有沒有一種方法可以統一對敏感信息進行脫敏處理呢?

答案是有的,我們可以基于 log4j2 實現自己的脫敏策略,統一實現日志的脫敏。

log4j2 Rewrite

我們可以基于 log4j2 RewritePolicy 統一使用脫敏策略。

本項目自 V1.2.0 添加對應支持,后續將提升對應的可拓展性。

說明:如果使用 slf4j 接口,實現為 log4j2 時也是支持的。

使用入門

maven 引入

引入核心脫敏包。

<dependency>
    <groupId>com.github.houbb</groupId>
    <artifactId>sensitive-log4j2</artifactId>
    <version>1.2.1</version>
</dependency>

其他的一般項目中也有,如 log4j2 包:

<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>${log4j2.version}</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>${log4j2.version}</version>
</dependency>

log4j2.xml 配置

例子如下:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN" packages = "com.github.houbb.sensitive.log4j2.rewrite">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
        </Console>
        <Rewrite name="rewrite">
            <AppenderRef ref="Console"/>
            <SensitiveRewritePolicy/>
        </Rewrite>
    </Appenders>
    <Loggers>
        <Root level="DEBUG">
            <AppenderRef ref="rewrite" />
        </Root>
    </Loggers>
</Configuration>

幾個步驟:

  • 指定 package 為 packages = "com.github.houbb.sensitive.log4j2.rewrite"。
  • 按照 log4j2 Rewrite 規范,指定重寫策略為 SensitiveRewritePolicy。
  • 輸出時,直接指定為對應的重寫之后的結果 <AppenderRef ref="rewrite" />。

測試

正常的日志打印:

private static final String TEST_LOG = "mobile:13088887777; bankCard:6217004470007335024, email:mahuateng@qq.com, amount:123.00, " +
        "IdNo:340110199801016666, name1:李明, name2:李曉明, name3:李澤明天, name4:山東小栗旬" +
        ", birthday:20220517, GPS:120.882222, IPV4:127.0.0.1, address:中國上海市徐匯區888號;";


logger.info(TEST_LOG);

自動脫敏效果如下:

mobile:130****7777|9FC4D36D63D2B6DC5AE1297544FBC5A2; bankCard:6217***********5024|444F49289B30944AB8C6C856AEA21180, email:mahu*****@qq.com|897915594C94D981BA86C9E83ADD449C, amount:123.00, IdNo:3****************6|F9F05E4ABB3591FC8EA481E8DE1FA4D6, name1:李*|15095D14367F7F02655030D498A4BA03, name2:李**|035E3C0D1A0410367FE6EB8335B2BFDE, name3:李澤**|B87138E5E80AEC87D2581A25CAA3809D, name4:山東***|6F2178D34BC7DD0A07936B5AFF39A16F, birthday:********|1F88D983FAFC50022651122B42F084A0, GPS:**********|E281A9A52DE915154285148D68872CA2, IPV4:127******|F528764D624DB129B32C21FBCA0CB8D6, address:中國上海市徐******|821A601949B1BD18DCBAAE27F2E27147;

ps: 這里是為了演示各種效果,實際默認對應為 1,2,3,4 這幾種策略。

log4j2 配置定制化

為了滿足各種用戶的場景,在 V1.2.1 引入了 SensitiveRewritePolicy 策略的可配置化。

默認配置

log4j2 配置中,SensitiveRewritePolicy 配置默認等價于

<SensitiveRewritePolicy
        prefix=":='""
        scanList = "1,2,3,4"
        replaceList = "1,2,3,4"
        defaultReplace = "12"
        replaceHash = "md5"
/>

屬性說明

SensitiveRewritePolicy 策略的屬性說明。

屬性

說明

默認值

備注

prefix

需要脫敏信息的匹配前綴

:='"

降低誤判率

replaceHash

哈希策略模式

md5

支持 md5/none 兩種模式

scanList

敏感掃描策略列表

1,2,3,4

1~10 內置的10種敏感信息掃描策略,多個用逗號隔開

replaceList

敏感替換策略列表

1,2,3,4

1~10 內置的10種敏感信息替換策略,多個用逗號隔開

defaultReplace

敏感替換默認策略

12

1~13 內置的13種敏感信息替換策略,指定一個。當列表沒有匹配時,默認使用這個

其中 1-13 的內置策略說明如下:

策略標識

說明

1

手機號

2

身份證

3

銀行卡

4

郵箱

5

中國人名

6

出生日期

7

GPS

8

IPV4

9

地址

10

護照

11

匹配任意不掩蓋

12

匹配任意半掩蓋

13

匹配任意全掩蓋

不足之處

這里的策略自定義和 log4j2 的插件化比起來,確實算不上強大,但是可以滿足 99% 的脫敏場景。

后續有時間考慮類似 log4j2 的 plugins 思想,實現更加靈活的自定義策略。

性能

正則的替換可能會導致 cpu 飆升等問題,替換的策略也有限制。

實現的底層不是基于正則的,性能要遠高于正則,大概是 2 倍左右,符合企業級應用性能。

后續將添加對應的 benchmark。

小結

實際項目中,建議二者結合使用。

基于 log4j2 的方式統一處理非常方便,但是是性能和準確性要有一定的折中。

如果是新項目,建議使用注解的方式,通過日志標準規范開發,后續拓展性也更加靈活。

責任編輯:姜華 來源: 今日頭條
相關推薦

2022-05-07 10:09:01

開發Java日志

2020-09-14 13:12:17

支付中心數據架構

2022-01-27 09:16:08

CPU內存.NET

2021-12-30 08:55:41

Log4j2FastJson漏洞

2021-04-02 07:58:36

LogbackLog4j2日志

2023-12-29 18:13:27

Spring日志應用程序

2021-12-11 13:29:36

SpringBoot 官方

2024-01-03 07:19:19

LogbackLog4j2Java

2021-04-09 11:15:24

LogbackLog4j2Java

2022-02-13 23:51:44

DeepfenceLog4j2漏洞

2020-11-04 12:33:08

Log4j 2日志Logback

2021-12-13 07:28:34

Java漏洞復現

2021-12-16 10:43:04

黑客網絡攻擊漏洞

2009-07-08 14:33:46

Java日志框架Log4J

2013-05-21 10:58:43

Log4jActiveMQSpring

2024-11-11 00:38:13

Mypy靜態類型

2021-12-10 15:08:09

Log4j2漏洞日志

2021-12-29 06:54:23

Log4j2 漏洞績效

2022-12-30 08:31:27

MDC查詢日志
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线成人福利 | 日韩在线中文字幕 | 亚洲日本一区二区 | 国产成人精品一区二 | 欧美videosex性极品hd | 亚洲国产成人精品久久 | 日本aaaa | 国产精品久久久久无码av | 亚洲 一区| 天天夜夜人人 | 欧美久久一级特黄毛片 | 精品国产欧美一区二区 | 性欧美精品一区二区三区在线播放 | 国产精品不卡 | 一区二区三区中文字幕 | 国产福利小视频 | 国产精品久久久久无码av | 美女精品一区 | 色毛片 | 视频一二三区 | 亚洲喷水 | 日日综合| 国产一区二区三区色淫影院 | 国产亚洲精品91 | 日韩av在线一区 | 精品二区视频 | 日韩欧美在线视频 | 日本电影免费完整观看 | 欧美精品成人影院 | 国产成人精品网站 | 81精品国产乱码久久久久久 | 二区在线视频 | 亚洲精品一区在线观看 | gav成人免费播放视频 | h片在线观看免费 | 欧美色综合 | 日韩免费高清视频 | 拍真实国产伦偷精品 | 国产日韩精品视频 | 91亚洲一区 | 日韩欧美亚洲 |