解决qq邮箱发送邮件失败javax.mail.AuthenticationFailedException

问题原因:

QQ邮箱的SSL加密连接已经默认开启,
SSL协议(Secure Socket Layer,安全套接层)是由网景(Netscape)公司推出的一种安全通信协议,
是对计算机之间整个会话进行加密的协议。

解决办法:

注意JavaMail的版本,要包含com.sun.mail.util.MailSSLScoketFactory类,1.4.2和其以上的版本应该可以。

import java.io.UnsupportedEncodingException;
import java.security.GeneralSecurityException;
import java.util.Date;
import java.util.Properties;

import javax.mail.Address;
import javax.mail.Authenticator;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;

import com.sun.mail.util.MailSSLSocketFactory;



public class EmailSendTool {
	// 邮箱服务器
	private String host;
	// 这个是你的邮箱用户名
	private String username;
	// 你的邮箱密码
	private String password;

	private String mail_head_name = "this is head of this mail";

	private String mail_head_value = "this is head of this mail";

	private String mail_to;

	private String mail_from;

	private String mail_subject = "this is the subject of this test mail";

	private String mail_body = "this is the mail_body of this test mail";

	private String personalName = "";
	

	public EmailSendTool() {
	}

	public EmailSendTool(String host, String username, String password,
			String mailto, String subject, String text, String name,
			String head_name, String head_value) {
		this.host = host;
		this.username = username;
		this.mail_from = username;
		this.password = password;
		this.mail_to = mailto;
		this.mail_subject = subject;
		this.mail_body = text;
		this.personalName = name;
		this.mail_head_name = head_name;
		this.mail_head_value = head_value;
	}

	/**
	 * 此段代码用来发送普通电子邮件
	 * 
	 * @throws MessagingException
	 * @throws UnsupportedEncodingException
	 * @throws GeneralSecurityException 
	 */
	public void send() throws MessagingException, UnsupportedEncodingException, GeneralSecurityException {
		Properties props = new Properties();
		Authenticator auth = new Email_Autherticator(); // 进行邮件服务器用户认证
		props.put("mail.smtp.host", host);
		props.put("mail.smtp.auth", "true");
		props.put("mail.transport.protocol", "smtp");
		MailSSLSocketFactory sf = new MailSSLSocketFactory();//ssl设置
		sf.setTrustAllHosts(true);
		props.put("mail.smtp.ssl.enable", "true");
		props.put("mail.smtp.ssl.socketFactory", sf);
		Session session = Session.getDefaultInstance(props, auth);
		// 设置session,和邮件服务器进行通讯。
		MimeMessage message = new MimeMessage(session);
		// message.setContent("foobar, "application/x-foobar"); // 设置邮件格式
		message.setContent(mail_body , "text/html;charset=utf-8");
		message.setSubject(mail_subject); // 设置邮件主题
		//message.setText(mail_body); // 设置邮件正文
		message.setHeader(mail_head_name, mail_head_value); // 设置邮件标题

		message.setSentDate(new Date()); // 设置邮件发送日期
		Address address = new InternetAddress(mail_from, personalName);
		message.setFrom(address); // 设置邮件发送者的地址
		Address toAddress = new InternetAddress(mail_to); // 设置邮件接收方的地址
		message.addRecipient(Message.RecipientType.TO, toAddress);
		

		Transport.send(message); // 发送邮件
	}

	/**
	 * 用来进行服务器对用户的认证
	 */
	public class Email_Autherticator extends Authenticator {
		public Email_Autherticator() {
			super();
		}

		public Email_Autherticator(String user, String pwd) {
			super();
			username = user;
			password = pwd;
		}

		public PasswordAuthentication getPasswordAuthentication() {
			return new PasswordAuthentication(username, password);
		}
	}

	public String getHost() {
		return host;
	}

	public void setHost(String host) {
		this.host = host;
	}

	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	public String getMail_head_name() {
		return mail_head_name;
	}

	public void setMail_head_name(String mail_head_name) {
		this.mail_head_name = mail_head_name;
	}

	public String getMail_head_value() {
		return mail_head_value;
	}

	public void setMail_head_value(String mail_head_value) {
		this.mail_head_value = mail_head_value;
	}

	public String getMail_to() {
		return mail_to;
	}

	public void setMail_to(String mail_to) {
		this.mail_to = mail_to;
	}

	public String getMail_from() {
		return mail_from;
	}

	public void setMail_from(String mail_from) {
		this.mail_from = mail_from;
	}

	public String getMail_subject() {
		return mail_subject;
	}

	public void setMail_subject(String mail_subject) {
		this.mail_subject = mail_subject;
	}

	public String getMail_body() {
		return mail_body;
	}

	public void setMail_body(String mail_body) {
		this.mail_body = mail_body;
	}

	public String getPersonalName() {
		return personalName;
	}

	public void setPersonalName(String personalName) {
		this.personalName = personalName;
	}

	public static void main(String[] args) {
		EmailSendTool sendEmail = new EmailSendTool("smtp.qq.com",
				"XXX@qq.com", "XXX", "XXX@qq.com",
				"主题", "邮件内容", "发送人名称", "", "");
		System.out.println("main");
		try {
			sendEmail.send();
		} catch (Exception e) {
			e.printStackTrace();
		}
		
	}

}


### 解析javax.mail.AuthenticationFailedException异常 当遇到`javax.mail.AuthenticationFailedException`异常时,通常意味着客户端无法通过身份验证来访问邮件服务器。此问题可能由多种因素引起,包括但不限于用户名或密码不正确、未启用必要的安全协议以及使用了错误类型的认证凭证。 对于特定于451错误的情况,该状态码表示服务器遇到了临时性的内部错误而无法处理请求。然而,在上下文中提到的具体问题是关于身份验证失败(535),这表明虽然服务器本身运行正常,但由于提供的凭据无效而导致操作被拒绝[^2]。 #### 配置检查与修正 为了成功发送电子邮件并避免上述异常,需确保应用程序配置文件中的参数设置无误: - **主机地址** (`spring.mail.host`) 和端口(`spring.mail.port`) 应匹配所使用邮件服务提供商的要求; - 用户名(`spring.mail.username`) 必须是有效的电子邮箱账号; - 密码字段(`spring.mail.password`) 不应填写常规登录密码而是应该填入专门为此应用创建的应用专用密钥或授权码[^5]; - 协议(`spring.mail.protocol`) 设置为 `smtps` 或者其他支持SSL/TLS加密传输的方式; - 启用 SSL 加密连接(`spring.mail.properties.mail.smtp.ssl.enable=true`) 并确认拼写准确性 (注意原文中存在拼写错误 "ture")[^4]。 ```yaml spring: mail: host: smtp.example.com port: 465 username: user@example.com password: app_specific_password_or_authorization_code protocol: smtps properties: mail: smtp: ssl: enable: true ``` #### 获取正确的授权令牌 如果正在使用像Gmail, QQ Mail, 163 Mail这样的第三方服务商,则需要前往对应的官方网站获取相应的授权令牌而不是直接采用账户默认登陆密码作为输入项。例如,在某些情况下,用户可以在其个人资料的安全设置里找到生成新授权码的功能入口。 #### 测试连通性和调试日志 建议开启详细的日志记录以便更好地理解整个过程中的每一步骤,并利用测试工具如Telnet命令行工具来进行简单的SMTP会话模拟以检验基本网络层面上能否顺利建立通信链路。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值