精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SpringBoot與Logback整合,實現敏感信息日志脫敏并且異步高效寫入?功能

開發 前端
?Logback 是一個強大且靈活的日志框架,適用于各種規模的應用程序。通過自定義 Appender,可以實現復雜的日志處理邏輯,如敏感信息脫敏和異步寫入,從而提升系統的安全性和性能。

Logback 是一個強大且靈活的日志框架,適用于各種規模的應用程序。通過自定義 Appender,可以實現復雜的日志處理邏輯,如敏感信息脫敏和異步寫入,從而提升系統的安全性和性能。

工作流程

圖片圖片

為什么需要自定義 Appender?

在某些情況下,默認的 Appender 無法滿足特定需求,例如:

  • 自動脫敏敏感信息。
  • 異步處理日志以提高性能。
  • 將日志發送到外部系統或服務。

代碼實操

<!-- Disruptor -->
    <dependency>
        <groupId>com.lmax</groupId>
        <artifactId>disruptor</artifactId>
        <version>3.4.4</version>
    </dependency>

    <!-- Logback Classic -->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
    </dependency>

創建自定義Appender

創建一個名為SensitiveDataMaskingAppender的類,該類繼承自AppenderBase<ILoggingEvent>,并在其中使用Disruptor隊列進行異步處理。

package com.example.demo.logging;

import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.AppenderBase;
import com.lmax.disruptor.*;
import com.lmax.disruptor.dsl.Disruptor;
import org.slf4j.MDC;

import java.util.concurrent.Executors;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

publicclass SensitiveDataMaskingAppender extends AppenderBase<ILoggingEvent> {

    // 正則表達式模式用于匹配身份證號碼
    privatestaticfinal Pattern ID_CARD_PATTERN = Pattern.compile("\\d{15}(\\d{2}[A-Za-z])?");
    // 正則表達式模式用于匹配手機號碼
    privatestaticfinal Pattern PHONE_NUMBER_PATTERN = Pattern.compile("(\\+86)?(1[3-9]\\d{9})");

    private RingBuffer<Event> ringBuffer;

    @Override
    public void start() {
        super.start();

        // 創建事件工廠
        EventFactory<Event> factory = Event::new;
        // 設置環形緩沖區大小,必須是2的冪
        int bufferSize = 1024;
        // 使用緩存線程池
        Executor executor = Executors.newCachedThreadPool();
        // 創建Disruptor實例
        Disruptor<Event> disruptor = new Disruptor<>(factory, bufferSize, executor,
                ProducerType.MULTI, new BusySpinWaitStrategy());
        // 設置事件處理器
        disruptor.handleEventsWith(new EventHandler<Event>() {
            @Override
            public void onEvent(Event event, long sequence, boolean endOfBatch) throws Exception {
                // 脫敏日志消息
                String logMessage = maskSensitiveData(event.getLogMessage());
                // 打印脫敏后的日志消息到控制臺
                System.out.println(logMessage);
            }
        });
        // 獲取RingBuffer
        ringBuffer = disruptor.getRingBuffer();
        // 啟動Disruptor
        disruptor.start();
    }

    @Override
    protected void append(ILoggingEvent eventObject) {
        // 獲取下一個序列號
        long sequence = ringBuffer.next(); 
        try {
            // 根據序列號獲取事件對象
            Event event = ringBuffer.get(sequence); 
            // 設置日志消息
            event.setLogMessage(eventObject.getMessage()); 
        } finally {
            // 發布事件
            ringBuffer.publish(sequence);
        }
    }

    /**
     * 脫敏日志消息中的敏感信息
     * @param message 日志消息
     * @return 脫敏后的日志消息
     */
    private String maskSensitiveData(String message) {
        Matcher idCardMatcher = ID_CARD_PATTERN.matcher(message);
        while (idCardMatcher.find()) {
            // 替換身份證號碼中間部分為星號
            String maskedIdCard = idCardMatcher.group().substring(0, 6) + "********" + idCardMatcher.group().substring(14);
            message = message.replace(idCardMatcher.group(), maskedIdCard);
        }

        Matcher phoneNumberMatcher = PHONE_NUMBER_PATTERN.matcher(message);
        while (phoneNumberMatcher.find()) {
            // 替換手機號碼中間部分為星號
            String maskedPhoneNumber = phoneNumberMatcher.group().substring(0, 3) + "****" + phoneNumberMatcher.group().substring(7);
            message = message.replace(phoneNumberMatcher.group(), maskedPhoneNumber);
        }

        return message;
    }

    // 定義事件類
    privatestaticclass Event {
        private String logMessage;

        public String getLogMessage() {
            return logMessage;
        }

        public void setLogMessage(String logMessage) {
            this.logMessage = logMessage;
        }
    }
}

配置Logback使用自定義Appender

在src/main/resources/logback-spring.xml文件中配置自定義appender:

<configuration>
    <!-- 自定義Appender配置 -->
    <appender name="SENSITIVE_MASKING_APPENDER" class="com.example.demo.logging.SensitiveDataMaskingAppender">
    </appender>

    <!-- 根Logger配置 -->
    <root level="info">
        <appender-ref ref="SENSITIVE_MASKING_APPENDER"/>
    </root>
</configuration>

創建Controller、Service和Repository層

Controller層

創建一個簡單的控制器來測試日志記錄功能。

package com.example.demo.controller;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
publicclass UserController {

    // 獲取日志記錄器
    privatestaticfinal Logger logger = LoggerFactory.getLogger(UserController.class);

    /**
     * 處理/user請求,記錄用戶信息并返回響應
     * @param idCard 用戶身份證號碼
     * @param phoneNumber 用戶手機號碼
     * @return 響應字符串
     */
    @GetMapping("/user")
    public String getUserInfo(@RequestParam String idCard, @RequestParam String phoneNumber) {
        // 記錄用戶信息到日志
        logger.info("User Info - ID Card: {}, Phone Number: {}", idCard, phoneNumber);
        return"User info logged";
    }
}

啟動類

package com.example.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}

測試

curl "http://localhost:8080/user?idCard=123456123456123456&phnotallow=13800138000"

控制臺日志

User Info - ID Card: 123456********56, Phone Number: 138****8000
責任編輯:武曉燕 來源: Java知識日歷
相關推薦

2025-03-11 08:34:22

2024-09-05 08:58:37

2025-09-08 09:14:31

SpringQuartz自動識別

2023-10-09 07:37:01

2023-10-27 08:46:34

DFA算法工具

2025-02-14 09:07:35

2024-12-24 08:44:55

ActiveMQRabbitMQ交換機

2025-05-20 09:00:04

SpringGeoHash派單

2025-07-22 03:15:00

SpringFlight零拷貝

2025-05-16 08:55:58

2023-06-06 08:51:06

2025-03-20 08:57:54

Spring日志存儲系統

2025-03-19 08:36:55

2025-03-26 08:43:17

2025-07-31 08:58:50

2025-05-23 08:37:26

2025-10-14 07:38:40

2025-04-23 08:50:00

SpringBootCurator分布式鎖

2021-10-28 07:56:52

多線程日志系統嵌入式開發

2025-11-21 08:08:57

點贊
收藏

51CTO技術棧公眾號

成人一对一视频| 国产中文字幕亚洲| 少妇特黄一区二区三区| 亚洲天堂资源| 欧美激情综合在线| 成人在线中文字幕| 国产大片aaa| 国产一区二区电影在线观看| 欧美视频一二三区| 丰满人妻一区二区三区53号| 亚洲 欧美 自拍偷拍| 日韩精品一二三四| 久久6免费高清热精品| 中出视频在线观看| 在线免费成人| 欧美特级www| 宅男噜噜99国产精品观看免费| 午夜久久久久久噜噜噜噜| 男人的天堂亚洲| 欧美成人第一页| av小说在线观看| 中文一区二区三区四区| 在线观看免费一区| 97在线国产视频| 免费av网站在线观看| av资源网一区| 亚洲一区二区三区sesese| 日韩精品一区不卡| 亚洲黄色天堂| 久久精品免费电影| a天堂中文字幕| 亚洲va欧美va人人爽成人影院| 欧美性xxxx在线播放| 米仓穗香在线观看| 五月天婷婷在线视频| 91啪亚洲精品| 国产91精品入口17c| 中日精品一色哟哟| 亚洲在线黄色| 久久久久久久国产| 欧美精品久久久久久久久46p| 国产精品免费大片| 日韩精品免费在线播放| 日韩精品xxx| 亚洲精品成a人ⅴ香蕉片| 色哟哟精品一区| 少妇高潮喷水在线观看| 性爱视频在线播放| 中文字幕日本不卡| 亚洲午夜精品一区二区三区| 精品美女视频在线观看免费软件 | 99国产精品久久久| 91在线在线观看| 国产99对白在线播放| 久久国产福利国产秒拍| 国产精品久久久久久亚洲调教| 中文字幕视频网| 99精品免费| 91精品国产高清自在线看超| 伊人国产在线观看| 中文国产一区| 欧美亚洲日本黄色| 黄色在线视频网址| 久热精品视频| 国产精品扒开腿做爽爽爽男男| 久久久久久91亚洲精品中文字幕| 99精品免费视频| 奇米四色中文综合久久| 日本中文字幕第一页| 久久激情网站| 国产精品入口免费视| 最近中文字幕在线观看| 男女男精品网站| 成人国产精品免费视频| 国产色片在线观看| 国产不卡高清在线观看视频| 丁香五月网久久综合| 手机福利小视频在线播放| av午夜一区麻豆| 日本一区二区精品| 国产精品麻豆一区二区三区| 国产精品久久久久影视| 日韩一二区视频| 91九色国产在线播放| 欧美性xxxxx极品| 亚洲欧美在线精品| 国产激情综合| 亚洲成人激情视频| 人人人妻人人澡人人爽欧美一区| 日韩高清欧美| 九色精品免费永久在线| 69国产精品视频免费观看| 奇米综合一区二区三区精品视频| 亚洲v日韩v综合v精品v| 欧美一级片免费| 国产欧美日韩久久| 穿情趣内衣被c到高潮视频| av丝袜在线| 欧美色精品在线视频| 4438x全国最大成人| 亚洲欧美日本伦理| xxav国产精品美女主播| 特一级黄色大片| 狠狠色综合播放一区二区| 国产精品三区www17con| 成人在线免费公开观看视频| 亚洲一线二线三线视频| mm1313亚洲国产精品无码试看| 精品午夜视频| 亚洲天堂av电影| 欧美人妻一区二区| 久久久久国产精品午夜一区| 2014亚洲精品| aaa在线观看| 亚洲成人自拍偷拍| 三级av免费看| 国产欧美高清视频在线| 国模吧一区二区| 夜夜狠狠擅视频| 91一区二区在线观看| 亚洲精品偷拍视频| jizz国产在线| 狠狠色2019综合网| 欧美不卡三区| 欧美videossex| 欧美日韩高清一区二区| 屁屁影院国产第一页| 婷婷综合伊人| 国产精品久久久久久久久久ktv| 亚洲免费视频网| 国产精品美女视频| 久久久久久久久久福利| 加勒比中文字幕精品| 久久久国产一区二区| 中文字幕日韩免费| www.在线成人| 国产免费裸体视频| 免费精品一区| 久久久国产一区二区| 最近中文字幕在线观看| 久久精品无码一区二区三区| 久久成人免费观看| 国偷自产av一区二区三区| 欧美另类精品xxxx孕妇| 国产精品视频第一页| 国产精品美女视频| 91插插插插插插插插| jizzjizz欧美69巨大| 日本91av在线播放| 青青草观看免费视频在线| 精品成人在线视频| 四季av综合网站| 亚洲欧洲一级| 久久99精品国产一区二区三区 | 欧美精品第一页在线播放| 国产99视频在线| 亚洲精品国产a| 丰满人妻一区二区三区大胸| 黑丝一区二区三区| 国产精品手机在线| 国产三级电影在线播放| 亚洲精品二三区| 天天操天天操天天操天天| 久久一区二区三区四区| 日本新janpanese乱熟| 久久国产电影| 1卡2卡3卡精品视频| xxxcom在线观看| 亚洲激情成人网| 日本三级免费看| 成人高清视频在线观看| 国产精品视频一二三四区| 久久国际精品| 欧美国产一区二区三区| 亚洲精品一区二区三区新线路| 一区二区三区四区视频精品免费 | 成人中文字幕合集| 波多野结衣av一区二区全免费观看| 国产精品日本一区二区三区在线 | 成人系列视频| 国产精品久久久久久久久影视 | 精品国产三区在线| 一本久久综合亚洲鲁鲁| 国产精品高潮呻吟AV无码| 亚洲人精品一区| 美女又黄又免费的视频| 亚洲精品四区| 久久av免费观看| 在线成人视屏| 久久精品欧美视频| 国内精品久久久久久久久久| 亚洲影视在线播放| 男人的天堂影院| 三级精品在线观看| 亚洲第一页在线视频| 欧美中文高清| 91禁国产网站| 日本精品在线| 精品精品国产高清a毛片牛牛 | 亚洲美女免费在线| 中文字幕第3页| 三级在线观看一区二区 | 免费看av毛片| 在线看日本不卡| 国产大片免费看| 99久久精品一区二区| 欧美黄色一级片视频| 亚洲人成免费网站| 国产三区精品| av在线播放一区| 欧美高清视频在线观看| 久久综合九色综合久| 欧美一区二区三区四区五区| 日本亚洲欧美在线| 国产精品全国免费观看高清| 好吊操视频这里只有精品| 久久精品电影| 国产一级爱c视频| 日韩av密桃| 国产美女在线精品免费观看| 成人18视频在线观看| 乱亲女秽乱长久久久| av资源网在线观看| 精品免费国产一区二区三区四区| 狠狠狠狠狠狠狠| 亚洲制服丝袜av| 天天色影综合网| 久久综合久久综合久久| 成人日韩在线视频| 噜噜噜久久亚洲精品国产品小说| 日本视频一区在线观看| 在线一区二区三区视频| 国产欧美精品一区二区| 久久电影tv| 欧美激情第三页| h视频在线播放| 日韩精品在线观看一区| 国产伦一区二区| 欧美亚洲愉拍一区二区| 成人午夜视频精品一区| 亚洲欧美区自拍先锋| 国产精品无码专区| 99国产精品99久久久久久| 性折磨bdsm欧美激情另类| 青青草97国产精品免费观看无弹窗版| 777精品久无码人妻蜜桃| 亚洲国产高清一区| 国产成人免费高清视频| 99精品一区| 亚洲一区二区精品在线| 精品国产一区二区三区| 久久精品国产综合精品| 2020最新国产精品| 亚洲free性xxxx护士hd| 日本美女久久| 成人xvideos免费视频| 亚洲精品粉嫩美女一区| 欧美综合在线第二页| 国产理论在线| 欧洲永久精品大片ww免费漫画| 成年女人在线看片| 久久久久久国产精品久久| 肉肉视频在线观看| 97高清免费视频| 8x8ⅹ拨牐拨牐拨牐在线观看| 久久电影一区二区| 国产剧情在线| 久久国产精品久久久久久久久久| 黄色网址免费在线观看| 久久综合久久美利坚合众国| 黄网页免费在线观看| 日韩最新在线视频| 巨大荫蒂视频欧美另类大| 久久精品美女视频网站| av文字幕在线观看| 欧美激情二区三区| 欧美极品videos大乳护士| 欧洲精品毛片网站| 日韩免费小视频| 国产精品91在线观看| 黄色精品视频| 亚洲japanese制服美女| 中文一区二区三区四区| 欧美一级二级三级九九九| 欧美一区二区三区激情视频| 色姑娘综合网| 91精品国产麻豆国产在线观看 | 国产有码一区二区| 视频亚洲一区二区| 国产三区精品| 欧美超碰在线| 国产乱人伦精品一区二区三区| 影音先锋中文字幕一区| 国产一区二区视频播放| 日韩二区三区四区| 青娱乐国产精品视频| 99久久久国产精品免费蜜臀| 丰满少妇一区二区三区| 中文字幕日韩av资源站| 日本一二三区不卡| 91九色最新地址| 国产美女免费视频| 亚洲福利视频久久| 成人在线免费观看| 欧美激情视频网址| 国产成人免费精品| 粉嫩av四季av绯色av第一区| 蜜桃一区二区| 国产911在线观看| 日韩电影免费在线看| 日韩a一级欧美一级| 91在线观看视频| 午夜国产福利视频| 一本久久精品一区二区| 精品人妻无码一区二区三区蜜桃一| 亚洲精品国产精品国自产观看浪潮| 国产区视频在线| 美女视频久久黄| 韩国精品一区| 91视频8mav| jvid福利在线一区二区| 免费拍拍拍网站| 香蕉久久夜色精品国产| 国产情侣久久久久aⅴ免费| 中文字幕欧美国产| 日韩欧美一区二区一幕| 精品久久免费看| 韩国av网站在线| 国产精品a久久久久久| 丝袜美腿综合| xxxxxx在线观看| 免费不卡在线视频| 亚洲专区区免费| 日韩欧美a级成人黄色| 成人黄色免费视频| 久久精品视频导航| 色婷婷成人网| 日韩免费av一区二区三区| 亚洲成人资源| 国产精品视频久久久| www.亚洲.com| 97视频在线观看成人| 激情综合五月| 不卡中文字幕在线| 青青草国产精品97视觉盛宴| 国产色视频一区二区三区qq号| 一区二区三区在线免费观看| 在线观看免费高清视频| 亚洲女人被黑人巨大进入| av电影免费在线看| 国产日韩欧美二区| 亚洲午夜av| 日本r级电影在线观看| 亚洲激情第一区| 国产黄a三级三级三级| 欧美成人免费网| 天天综合91| 国产四区在线观看| 精品一区二区三区在线观看| 天堂av网手机版| 91精品福利在线| 国产区视频在线| 国产精自产拍久久久久久蜜| 手机在线电影一区| 日韩av卡一卡二| 中文字幕亚洲视频| 国产精品无码粉嫩小泬| 一区二区三区国产视频| yw.尤物在线精品视频| 在线观看成人av| 国产在线精品免费av| 老熟妇高潮一区二区三区| 欧美色网站导航| 最近中文字幕免费mv2018在线| 亚洲自拍偷拍视频| 国模大胆一区二区三区| 国产精品无码毛片| 色哟哟日韩精品| 日本中文字幕在线视频| 国产精品一区视频网站| 亚洲美女黄网| 青青草福利视频| 911精品国产一区二区在线| 超碰在线最新| 国产在线精品一区二区中文| 日本在线不卡视频| 精品国产视频在线观看| 精品欧美久久久| 国产精品videossex撒尿| 伊人色综合久久天天五月婷| 加勒比av一区二区| 伊人中文字幕在线观看| 综合av色偷偷网| 精品国产乱码一区二区三区 | 国产精品自产拍在线观看| 91精品国产视频| 日本黄色录像片| 在线播放中文一区| 国模雨婷捆绑高清在线| 欧美高清性xxxxhdvideosex|