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

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

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

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <!--log4j-slf4j-impl与 logback-classic包不兼容,删除这个包 -->
                    <groupId>ch.qos.logback</groupId>
                    <artifactId>logback-classic</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
            <!--改用log4j这里去掉原本logback依赖-->
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>commons-logging</groupId>
            <artifactId>commons-logging</artifactId>
            <version>1.2</version>
        </dependency>

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();
        }

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

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

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

over!

 

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值