无法读取 log4j2 属性文件中的系统属性

问题描述

我正在尝试将系统属性中的 SMTPhost、emailAddress 读入 log4j2.properties。 我搜索并找到了

${sys:log4j.smtpHost}

但它没有读取值。我正在使用弹簧靴。

log4j2.properties

appender.email=org.apache.net.SMTPAppender
appender.email.type=smtp
appender.email.name = Email
appender.email.SMTPHost=${sys:log4j.smtpHost}
appender.email.From=${sys:log4j.emailAddressFrom}
appender.email.BufferSize=512
appender.email.layout.type=PatternLayout
appender.email.layout.Pattern=[%x%d{ISO8601}]%n%n%-5p%n%n%c%n%n%m%M%n%n

Java 文件

            InitialContext initialContext = new javax.naming.InitialContext();
            Properties props = System.getProperties();
            props.put("log4j.smtpHost",initialContext.lookup("java:comp/env/log4j.smtpHost"));
            props.put("log4j.fatal.emailAddress",initialContext.lookup("java:comp/env/log4j.fatal.emailAddress"));\
            System.setProperties(props);

            ClassPathResource resource = new ClassPathResource("log4j2.properties");
            InputStream inputStream = resource.getInputStream();
            ConfigurationSource source = new ConfigurationSource(inputStream);
            Configurator.initialize(null,source);
            logger = LogManager.getLogger(WebConfiguration.class);

log4j2.properties 应该读取系统属性中设置的值。 也欢迎任何其他方法

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...