import org.apache.log4j.Logger;
import java.io.*;
public class ExampleHandler implements HttpHandler {
static Logger log = Logger.getLogger(log4jExample.class.getName());
public void handle(HttpExchange he) throws IOException {
String userAgent = he.getRequestHeader(“user-agent”);
log.info(“Request User Agent:” + userAgent);
String response = "
Hello There, " + userAgent + “!
”;he.sendResponseHeaders(200, response.length());
OutputStream os = he.getResponseBody();
os.write(response.getBytes());
os.close();
}
}
Apache Log4j 2.x <= 2.14.1
1、调整JVM参数 -Dlog4j2.formatMsgNoLookups=true
如果是SpringBoot微服务项目,在运行参数中加上
如果是传统Web项目,以Tomcat为例,在文件/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS=’-Dlog4j2.formatMsgNoLookups=true‘
2、修改配置 log4j2.formatMsgNoLookups=True
3、修改系统环境变量
FORMAT_MESSAGES_PATTERN_DISABLE_LOOKUPS 设置为true,进入Linux命令行,输入 vi /etc/profile,在最后加入
1、升级 Apache Log4j2 所有相关应用到最新的 log4j-2.15.0-rc2 版本,已发现官方修复代码,目前尚未正式发布
下载地址:https://github.com/apache/logging-log4j2/releases/tag/log4j-2.15.0-rc2
Github下载量巨大访问慢,可以关注回复微信公众号『 Tom弹架构 』回复“log4j” 下载最新版Log4j离线jar包。
2、升级已知受影响的应用及组件,如 srping-boot-strater-log4j2 / Apache Solr / Apache Flink / Apache Druid
据悉,Apache Log4j2 日志远程代码执行漏洞因此也影响了所有 Minecraft 服务器。
【影响版本】Apache log4j2 >= 2.0, <= 2.14.1
Minecraft 全版本所有系列服务端,除 Mohist 1.18 外。
[1] https://github.com/apache/logging-log4j2
[2] https://github.com/apache/logging-log4j2/commit/7fe72d6
关注微信公众号『 Tom弹架构 』回复“Spring”可获取完整源码。
写在最后
在结束之际,我想重申的是,学习并非如攀登险峻高峰,而是如滴水穿石般的持久累积。尤其当我们步入工作岗位之后,持之以恒的学习变得愈发不易,如同在茫茫大海中独自划舟,稍有松懈便可能被巨浪吞噬。然而,对于我们程序员而言,学习是生存之本,是我们在激烈市场竞争中立于不败之地的关键。一旦停止学习,我们便如同逆水行舟,不进则退,终将被时代的洪流所淘汰。因此,不断汲取新知识,不仅是对自己的提升,更是对自己的一份珍贵投资。让我们不断磨砺自己,与时代共同进步,书写属于我们的辉煌篇章。
需要完整版PDF学习资源私我
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!