我正在使用 Log4j 发送有关错误的电子邮件日志,并希望在 java 中的 log4j 中设置 SMTP 设置,而不是在属性文件中。设置密码有效,我可以成功发送电子邮件
private static final Logger logger = Logger.getLogger("emailer");
(...)
Enumeration<?> enm = logger.getAllAppenders();
while (enm.hasMoreElements()) {
Object element = enm.nextElement();
if (element instanceof SMTPAppender) {
((SMTPAppender) element).setSMTPPassword(password);
}
}
但是,在 SMTPAppender 中使用其他设置器不会执行任何操作(设置主机、用户名等),并且 log4j 将继续使用属性文件的设置。
(...)
log4j.logger.emailer=stdout, email
log4j.additivity.emailer=false
log4j.appender.email=org.apache.log4j.net.SMTPAppender
log4j.appender.email.SMTPHost=smtp.gmail.com
log4j.appender.email.SMTPPort=465
log4j.appender.email.SMTPUsername=username@gmail.com
log4j.appender.email.SMTPPassword=-
log4j.appender.email.From=username@gmail.com
log4j.appender.email.to=username@gmail.com
log4j.appender.email.Subject=Error Alert
log4j.appender.email.layout=org.apache.log4j.PatternLayout
log4j.appender.email.layout.ConversionPattern=%d [%t] %-5p %c %x - %m%n
log4j.appender.email.BufferSize=10
log4j.appender.email.Threshold=ERROR