SpringBoot集成slf4j+log4j并输出到加密密码的数据库

本文根据实战经验复写SpringBoot+slf4j+log4j的日志集成方式,并配置相关控制台、文件、密码加密数据库输出打印等方式。

1、SpringBoot项目中的log4j maven相关依赖和原logback(SpringBoot自带)解除:

        
            org.springframework.boot
            spring-boot-starter-web
            
                
                    
                    ch.qos.logback
                    logback-classic
                
            
        
        
            org.springframework.boot
            spring-boot-starter
            
            
                
                    org.springframework.boot
                    spring-boot-starter-logging
                
            
        
        
            commons-logging
            commons-logging
            1.2
        

2、application.properties或yml文件的配置如下加入一行:

#log4j2配置路径
logging.config=classpath:log4j.properties

3、log4j文件的配置,详细参数及说明如下,错误日志会打印到单独的一个文件,普通级别打印则会输出到普通文件并每日产生一个新文件:

# The five logging levels used by Log are (in order):
#   1. DEBUG 2. INFO 3. WARN 4. ERROR 5. FATAL (the most serious)
# Set root logger level to WARN and append to S
log4j.rootLogger=INFO,S,R,E,D
#######################
# 控制台打印
log4j.appender.S=org.apache.log4j.ConsoleAppender
log4j.appender.S.layout=org.apache.log4j.PatternLayout
log4j.appender.S.layout.ConversionPattern=%d %5p (%c:%L) - %m%n
#######################
# 每天新增一个文件
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.File=D:\\pingan\\log\\sentiAnalys.log
log4j.appender.R.Append=true
log4j.appender.R.DatePattern='.'yyyy-MM-dd'.log'
##输出INFO级别以上的日志
log4j.appender.R.Threshold=INFO
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=[%d] %5p (%c:%L) - %m%n
#######################
# 保存异常信息到单独文件
log4j.appender.E=org.apache.log4j.DailyRollingFileAppender
## 异常日志文件名
log4j.appender.E.File=D:\\pingan\\log\\sentiAnalysErr.log
log4j.appender.E.Append=true
log4j.appender.E.Threshold=ERROR
## 只输出ERROR级别以上的日志!!!
log4j.appender.E.layout=org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
#######################
# 数据库输出 加密psd
log4j.appender.D=com.pa.data.log.JDBCAppenderFix
log4j.appender.D.URL=jdbc:mysql://localhost:3306/padata
log4j.appender.D.driver=com.mysql.jdbc.Driver
log4j.appender.D.user=root
log4j.appender.D.password=NcOVb4IWFVw=
log4j.appender.D.sql=INSERT INTO syslog(CREATEDATE,THREAD,GRADE,CLASS,MESSAGE,PID,CURRENTSTATE) values('%d','%t','%-5p','%c','%m','%X{pid}',%X{currentstate})
log4j.appender.D.layout=org.apache.log4j.PatternLayout
log4j.appender.D.Threshold=ERROR
log4j.appender.D.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
###注意,pid,和currentstate是要在日志在输入给数据库之前,必须先设置好,在logger.ERROR(“…”)之前传入MDC自定义的参数值:
###MDC.put("pid", pid);
###MDC.put("currentstate", 1);
###不追加字段则可用 log4j.appender.D.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#
# Print only messages of level ERROR or above in the package noModule.
log4j.logger.noModule=FATAL
log4j.logger.com.pa=DEBUG
注意 log4j.rootLogger=INFO,S,R,E,D 中,先写入INFO是能让控制台打印所有日志。

4、如上数据库打印所用的jdbc密码采用的是DES+base64转换的加密方式,实现方法网上比较多。目标表创建sql如下,

DROP TABLE IF EXISTS `syslog`;
CREATE TABLE `syslog` (
  `CREATEDATE` varchar(128) default NULL,
  `THREAD` varchar(128) default NULL,
  `GRADE` varchar(128) default NULL,
  `CLASS` varchar(128) default NULL,
  `MESSAGE` text,
  `PID` bigint(20) default NULL,
  `CURRENTSTATE` varchar(255) default NULL,
  `AUTOID` bigint(20) NOT NULL auto_increment,
  PRIMARY KEY  (`AUTOID`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;

同时,需要重写JDBCAppender日志appender,如这里继承实现类JDBCAppenderFix,并设置

log4j.appender.D=com.pa.data.log.JDBCAppenderFix

重写类步骤如下。

5、复写JDBCAppender(继承)为JDBCAppenderFix,该类的具体作用就是给log4j配置文件中的jdbc密码解密:

package com.pa.data.log;

import com.pa.analysis.utils.DESUtil;
import org.apache.log4j.jdbc.JDBCAppender;

public class JDBCAppenderFix extends JDBCAppender {

    @Override
    public void setPassword(String password) {
        try {
            password = DESUtil.decryptStr(password);
        } catch (Exception e) {
            e.printStackTrace();
        }
        this.databasePassword = password;
    }
}

注意,DESUtil.decryptStr(password) 就是对上面配置密码的解密。

6、项目中使用,如上配置,普通的debug、info等日志输出会打印到相关控制台或文件,但是error级别会打印到另外文件和数据库,打印到控制台和记录文件的使用如下:

private final Logger logger = LoggerFactory.getLogger(getClass());
……………………
logger.info("XX Factory create YY bean OK!");

这里设置的是,如果为error级别则会打印到另外一个文件和数据库:

private final Logger logger = LoggerFactory.getLogger(getClass());
………………………………
try {
            afterEnc = DESUtil.encryptStr(str);//异常则打印错误
        } catch (Exception e) {
            MDC.put("pid", "123");
            MDC.put("currentstate", "1");
            logger.error(e.getMessage().toString());
            return "error:" + e.getMessage();
        }

—————————————————————————————

普通的文件和控制台打印正常,数据库打印的日志查看效果如下:

SpringBoot集成slf4j+log4j并输出到加密密码的数据库_第1张图片

分普通日志和错误日志的文件打印效果如下:

over!

 

log4j部分配置参考:https://www.cnblogs.com/tapt/p/8056457.html

 

你可能感兴趣的:(JAVA框架)