IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 【log4j漏洞研究】log4j通过slf4j转logback -> 正文阅读

[移动开发]【log4j漏洞研究】log4j通过slf4j转logback

log4j项目

pom.xml

 <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
        <log.version>2.14.0</log.version>
        <!-- jdk7升级倒2.12.4, jdk8升级到2.17.1 -->
<!--        <log.version>2.17.1</log.version>-->
<!--                <log.version>2.15.0</log.version>-->
    </properties>

    <dependencies>



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

log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">

 <!--全局参数-->
 <Properties>
  <Property name="pattern">%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n</Property>
  <Property name="logDir">/data/logs/dust-server</Property>
 </Properties>

 <Loggers>
  <Root level="INFO">
   <AppenderRef ref="console"/>
   <AppenderRef ref="rolling_file"/>
  </Root>
 </Loggers>

 <Appenders>
  <!-- 定义输出到控制台 -->
  <Console name="console" target="SYSTEM_OUT" follow="true">
   <!--控制台只输出level及以上级别的信息-->
   <ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
   <PatternLayout>
    <Pattern>${pattern}</Pattern>
   </PatternLayout>
  </Console>
  <!-- 同一来源的Appender可以定义多个RollingFile,定义按天存储日志 -->
  <RollingFile name="rolling_file"
               fileName="${logDir}/dust-server.log"
               filePattern="${logDir}/dust-server_%d{yyyy-MM-dd}.log">
   <ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
   <PatternLayout>
    <Pattern>${pattern}</Pattern>
   </PatternLayout>
   <Policies>
    <TimeBasedTriggeringPolicy interval="1"/>
   </Policies>
   <!-- 日志保留策略,配置只保留七天 -->
   <DefaultRolloverStrategy>
    <Delete basePath="${logDir}/" maxDepth="1">
     <IfFileName glob="dust-server_*.log" />
     <IfLastModified age="7d" />
    </Delete>
   </DefaultRolloverStrategy>
  </RollingFile>
 </Appenders>
</Configuration>

Log4j2Demo

package org.example;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class Log4j2Demo {

    /**
     * 版本2.14.0:
     * 2022-03-08 10:44:15,130  INFO Log4j2Demo:10 - --------------start---------------
     * 2022-03-08 10:44:15,140  INFO Log4j2Demo:13 - Hello, Windows 10 10.0, architecture: amd64-64
     * 2022-03-08 10:44:15,140  INFO Log4j2Demo:14 - --------------end---------------
     *
     * 升级到2.15.0|2.17.1版本后:
     * 2022-03-08 10:49:42,866  INFO Log4j2Demo:19 - Hello, ${java:os}
     *
     */
    private static  final Logger LOGGER = LogManager.getLogger();
    public static void main(String[] args) {
        LOGGER.info("--------------start---------------");
        String username="1111${java:os}";

        LOGGER.info("Hello, {}",username);
        LOGGER.info("Hello, {}", "${java:os}");
        LOGGER.info("--------------end---------------");
    }
}

执行main函数发现如下,会存在安全漏洞
在这里插入图片描述

升级logback日志

pom.xml加上下面

        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.2.3</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-to-slf4j</artifactId>
            <version>2.8.2</version>
            <!--            <version>${log.version}</version>-->
        </dependency>

logback.xml

<configuration>
    <appender name="Console" class="ch.qos.logback.core.ConsoleAppender">
        <layout class="ch.qos.logback.classic.PatternLayout">
            <Pattern>
                [logback]%black(%d{ISO8601}) %highlight(%-5level) [%blue(%t)] %yellow(%C{1.}): %msg%n%throwable
            </Pattern>
        </layout>
    </appender>

    <root level="DEBUG">
        <appender-ref ref="Console" />
    </root>
</configuration>

再执行main函数,漏洞不存在了
在这里插入图片描述

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-05-12 16:33:51  更:2022-05-12 16:34:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 1:43:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码