`

log4j 发email 补充

    博客分类:
  • SSH
阅读更多

其实,那个牛人的方法有些麻烦,虽然SMTPAppender的smtpusername等属性是private的,但是有getsmtpusername()方法可以获得他们,所以只要改变

activateOptions()方法就可以,其他的只要继承SMTPAppender.class就可以了

具体代码如下

package com.hua.test;

import java.util.Properties;

import javax.mail.Authenticator;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import org.apache.log4j.helpers.LogLog;
import org.apache.log4j.net.SMTPAppender;

/**
 * SMTP Appender扩展,增加对邮件认证的支持
 * 
 * @author hua
 * 
 */
public class SMTPHua2Appender extends SMTPAppender {
	private String smtpAuth;



	public String getSmtpAuth() {
		return smtpAuth;
	}



	public void setSmtpAuth(String smtpAuth) {
		this.smtpAuth = smtpAuth;
	}



	@Override
	public void activateOptions() {
		// TODO Auto-generated method stub
		Properties props = new Properties(System.getProperties());
		Authenticator authenticator = null;
		
		if (getSMTPHost() != null)
			props.put("mail.smtp.host", getSMTPHost());

		/**//* ADD auth code */
		if (smtpAuth != null && smtpAuth.trim().equals("true")) {
			props.put("mail.smtp.auth", "true");
			authenticator = new Authenticator() {
				protected PasswordAuthentication getPasswordAuthentication() {
					return new PasswordAuthentication(getSMTPUsername(),
							getSMTPPassword());
				}
			};
		}

		Session session = Session.getInstance(props, authenticator);

		msg = new MimeMessage(session);
		try {
			InternetAddress fromAdd=new InternetAddress(getFrom());
			InternetAddress[] toAdd=InternetAddress.parse(getTo());
			if (getFrom() != null)
				msg.setFrom(fromAdd);
			else
				msg.setFrom();

			msg.setRecipients(Message.RecipientType.TO, toAdd);
			if (getSubject() != null)
				msg.setSubject(getSubject());
		} catch (MessagingException e) {
			LogLog.error("Could not activate SMTPAppender options.", e);
		}
	}

}

 

对应的log4j.properties

 

##ROOT 
log4j.rootLogger=INFO,CONSOLE,A_default,MAIL 

## CONSOLE 
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender 
log4j.appender.Threshold=INFO 
log4j.appender.CONSOLE.Target=System.out 
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout 
#log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n 
log4j.appender.CONSOLE.layout.ConversionPattern=[调试信息]%-5p %c %x - %m%n 

## A_default 
log4j.appender.A_default=org.apache.log4j.RollingFileAppender 
log4j.appender.A_default.Threshold=INFO 
log4j.appender.A_default.File=E://Log//log.txt 
log4j.appender.A_default.MaxFileSize=4000KB 
log4j.appender.A_default.MaxBackupIndex=10 
log4j.appender.A_default.layout=org.apache.log4j.PatternLayout 
log4j.appender.A_default.layout.ConversionPattern=[调试信息]%-5p %c %x - %m%n 

## MAIL 
##log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender 
log4j.appender.MAIL=com.hua.test.SMTPHua2Appender  
# 日志的错误级别 
log4j.appender.MAIL.Threshold=INFO 
# 缓存文件大小,日志达到512K时发送Email 
log4j.appender.MAIL.BufferSize=1 
# 发送邮件的服务器
log4j.appender.MAIL.SMTPHost=smtp.sina.com
# 邮件的标题 
log4j.appender.MAIL.Subject=Log4J ErrorMessage 
# 用户名 
log4j.appender.MAIL.SMTPUsername=doloveme70910054
# 密码 
log4j.appender.MAIL.SMTPPassword=xxxxx
# 发件人地址 
log4j.appender.MAIL.From=doloveme70910054@sina.com
log4j.appender.MAIL.smtpAuth=true
# 日志邮件的接收者 
log4j.appender.MAIL.To=doloveme70910054@sina.com
# 日志PatternLayout 
log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout 
# 日志的格式log4j.appender.MAIL.layout.ConversionPattern=[ErrorMessage] %d - %c -%-4r [%t] %-5p %c %x - %m%n

 

 

这样就好了,可以很轻松的DIY  log4j

1
1
分享到:
评论

相关推荐

    老生常谈Log4j和Log4j2的区别(推荐)

    下面我们将从配置文件类型、核心JAR包、文件渲染和Log调用四个方面来比较Log4j和Log4j2的区别。 配置文件类型 Log4j通过一个.properties文件作为主配置文件,而Log4j2则弃用了这种方式,采用的是.xml、.json或者....

    若依框架使用的log4j2.16.0,修复log4j漏洞log4j2下载最新log4j2.16.0下载

    Log4j是一个广泛使用的Java日志记录框架,它允许开发者在应用程序中轻松地记录各种级别的日志信息,如DEBUG、INFO、WARN、ERROR等。在2021年底,一个重大的安全漏洞(CVE-2021-44228)被发现在Log4j2的早期版本中,...

    logging-log4j2-log4j-2.15.0-rc2.zip maven 资源库

    针对Log4j 2 远程代码执行漏洞,需要用到的升级资源包,适用于maven资源库,包括log4j,log4j-core,log4j-api,log4j-1.2-api,log4j-jpa等全套2.15.0 maven资源库jar包。如果是maven本地仓库使用,需要将zip包解压...

    Log4j2学习用到的jar包及apache-log4j-2.19.0-bin.zip

    分别有disruptor-3.3.4.jar(Log4j2异步日志的底层实现)、log4j-api-2.19.0.jar(log4j门面)、log4j-core-2.19.0.jar(log4j实现)、log4j-slf4j-impl-2.19.0.jar(SLF4J与Log4j绑定)、slf4j-api-1.7.30.jar(SLF...

    log4j.jar各个版本

    apache-log4j-1.2.15.jar, apache-log4j-extras-1.0.jar, apache-log4j-extras-1.1.jar, apache-log4j.jar, log4j-1.2-api-2.0.2-javadoc.jar, log4j-1.2-api-2.0.2-sources.jar, log4j-1.2-api-2.0.2.jar, log4j-...

    Log4j2简介及与Log4j效率对比

    ### Log4j2简介 Log4j2是Apache软件基金会推出的日志框架,它是Log4j 1.x的重构版本,旨在提供更为高效且灵活的日志解决方案。与Log4j 1.x相比,Log4j2在设计上进行了重大改进,并解决了Logback等其他日志框架中...

    log4j-1.2-api-2.17.1、log4j-api-2.17.1、log4j-core-2.17.1、slf4j-api-1.7.36、log4j-slf4j-impl-2.17.1

    例如,如果项目需要使用log4j 1.2系列的API,那么可以选择log4j-1.2-api-2.17.1和相应的log4j-core。而如果项目希望使用log4j 2的高性能特性,那么可以选择log4j-api-2.17.1和log4j-core-2.17.1。通过SLF4J的抽象,...

    SpringBoot框架配置log4j和log4j2的配置代码

    Log4j和Log4j2是两种广泛使用的Java日志框架,它们提供了灵活的日志配置和高性能的日志处理能力。本文将详细介绍如何在SpringBoot项目中配置Log4j和Log4j2。 ### SpringBoot与Log4j Log4j是Apache的一个开源项目,...

    log4j-core-2.15.0.jar log4j-2.15.0-rc2

    Apache log4j2零日漏洞,根据 log4j-2.15.0-rc2 版本编译生成log4j-api-2.15.0.jar 1.解压你的jar jar xvf XXX.jar 2. 删除旧版本jar cd ./BOOT-INF/lib rm -rf log4j-api-*.jar 3. 上传新版本log4j-api-2.15.0....

    修复log4j漏洞log4j2下载最新log4j2.16.0下载 log4j-api-2.16.0.jar

    apache下载太慢,特搬到国内下载。修复log4j漏洞log4j2下载最新log4j2.16.0下载

    Log4j2、Fastjson、Log4j的BurpSuite插件亲测有效

    Log4j、Log4j2和Fastjson的安全性问题在过去曾引起广泛关注,例如Log4j2的CVE-2021-44228(也被称为Log4Shell漏洞),这是一个远程代码执行漏洞,影响了许多使用Log4j2的系统。这个插件可能就是为了检测和利用这些...

    log4j+slf4j实现 log4j测试代码,log4j+slf4j实现 log4j测试代码

    2. **配置Log4j**:在项目的类路径下创建`log4j.properties`或`log4j.xml`配置文件,指定日志级别、输出目的地等。例如: ```properties # log4j.properties log4j.rootLogger=DEBUG, stdout log4j.appender....

    log4j-api-2.12.4.ja和log4j-core-2.12.4.jar

    此次提及的`log4j-api-2.12.4.jar`和`log4j-core-2.12.4.jar`是Log4j 2框架的两个关键组件,版本号为2.12.4,这个版本主要修复了之前版本中可能存在的安全漏洞。 **log4j-api-2.12.4.jar** 是Log4j 2框架的API模块...

    log4j-2.18.0

    《log4j-2.18.0:修复重大安全漏洞的紧急更新》 在IT领域,安全性始终是首要关注的问题。近期,一个名为“log4j2”的严重安全漏洞引发了广泛关注,它影响了所有log4j2版本,从2.0开始直到2.18.0版本之前。这个漏洞...

    log4j-api-2.17.1.jar和log4j-core-2.17.1.jar

    《深入理解log4j-api-2.17.1.jar与log4j-core-2.17.1.jar》 在Java开发中,日志管理是不可或缺的一部分,它帮助我们跟踪程序运行状态、定位错误和调试问题。Log4j作为一款广泛使用的日志框架,历经多次迭代,现在...

    apache-log4j-2.17.0 核心jar包

    Log4j 是一个日志记录框架,Log4j 2 是对 Log4j 的升级,提供了重大改进,超越其前身 Log4j 1.x,并提供许多其它现代功能 ,例如对标记的支持、使用查找的属性替换、lambda 表达式与日志记录时无垃圾等。 Apache ...

    log4j-API-最新稳定版本log4j-1.2.17

    标题提及的是"log4j-API-最新稳定版本log4j-1.2.17",这表明我们关注的是日志框架Log4j的一个特定版本,即1.2.17。Log4j是Apache软件基金会开发的一个用于Java应用程序的日志记录工具,它提供了灵活的日志记录功能,...

    log4j.properties(完整版) log4j.properties(精简版)

    **日志框架Log4j详解** 在Java开发中,日志记录是一项不可或缺的功能,它能够帮助开发者追踪程序运行状态,定位错误,优化性能,并为后期维护提供重要信息。Log4j是Apache组织开发的一个强大的、灵活的日志记录框架...

    SSM整合中的Log4j日志的配置详情

    四、在 Maven 项目中引入 Log4j 依赖 在 Maven 项目中,需要引入 Log4j 依赖项,以便使用 Log4j。下面是一个基本的 Maven 依赖项配置: ``` <groupId>log4j <artifactId>log4j <version>1.2.16 ``` 这个配置...

    Log4j2学习log4j2.xml配置模板

    Log4j2 配置模板学习笔记 Log4j2 是 Java 语言中一种流行的日志记录工具,它提供了灵活的日志记录管理功能。下面我们将学习 Log4j2 配置模板的使用和配置。 引入 Log4j2 依赖 在使用 Log4j2 之前,需要在 Maven ...

Global site tag (gtag.js) - Google Analytics