【Java mail 入门教程】第五讲 邮件认证

在前面的教程里面我们都是用Session.getDefaultInstance(props)没有通过认证的方式取得session,这样明显的缺点是我们要连接邮件服务器的用户名和密码都要写死在代码里面,如:transport.connect("smtp.qq.com", "***@qq.com", "****");

store.connect("pop.qq.com", "*****@qq.com", "******");

这样子显得程序拓展性很差,如果要切换不同的用户就要修改源代码,这样是很麻烦的,还有用户名和密码明文地写在代码里很容易就泄露,这样是很不安全的。这一讲就是通过运用Authenticator类来进行邮件的认证。

Authenticator是一个抽象类,所以要extends Authenticator 抽象类在子类中覆盖父类中的 getPasswordAuthentication() 方法,就可以实现以不同的方式来进行登录邮箱时的用户身份认证。JavaMail 中的这种设计是使用了策略模式(Strategy),具体的请参看相关文章。

这一讲我们来建立一个通过对话框输入用户名和密码进行收发邮件。如果想了解不通过邮件认证连接服务器,请观看2~3讲的内容。

 

 

1、  首先我们建立一个继承Authenticator的子类。

import java.util.*;
  import javax.mail.*;
  import javax.swing.*;
 
  public class GUIAuthenticator extends Authenticator {
 
     protected PasswordAuthentication getPasswordAuthentication() {         
         String user;          
         String pwd;           
         // 弹出输入对话框         
          String result = JOptionPane.showInputDialog("请输入用户名和密码,以','隔开!");          
         StringTokenizer st = new StringTokenizer(result, ",");          
         user = st.nextToken();          
         pwd = st.nextToken();           
         return new PasswordAuthentication(user, pwd);      
     }
 }

作用:这个类的作用是在连接邮件服务器的时候,就会调用这个类的

getPasswordAuthentication方法,然后提示输入用户名和密码。

Ps:这个只是一个很简单的类,只作为一个例子给大家参考,真正的邮件认证不是那么简单的。

 

2、  通过邮件认证发送邮件:

package com.mail;
  import java.util.*;
 import javax.mail.*;
 import javax.mail.internet.*;
 /**
  * 通过邮件认证发送邮件
  * @author sam
  *
  */
 public class SendMailAuthenticator {
 
     private String smtpServer = "smtp.qq.com";
     private String from = "343820302@qq.com";
     private String to = "343820302@qq.com";
     private String subject = "测试使用邮件认证";
     private String body = "测试使用邮件认证正文";
 
     public void sendMail(Authenticator auth) throws Exception {
         // 设置协议、是否身份验证、服务器等信息
         Properties props = new Properties();
         props.setProperty("mail.transport.protocol", "smtp");
         props.setProperty("mail.smtp.auth", "true");
         props.setProperty("mail.host", smtpServer);
         // 通过传入的参数获得Authenticator子类对象
         Session session = Session.getInstance(props, auth);
         // 构造信息体
         MimeMessage message = new MimeMessage(session);
         // 发件地址
         Address fromAddress = new InternetAddress(from);
         message.setFrom(fromAddress);
         // 收件地址
         Address toAddress = new InternetAddress(to);
         message.setRecipient(MimeMessage.RecipientType.TO, toAddress);
 
         // 主题
         message.setSubject(subject);
         // 正文
         message.setText(body);
 
         message.saveChanges();
 
         session.setDebug(true);
 
         /*
          * * 由于Session对象中注册了Authenticator子类对象,因此可以直接 *
          * 从该Authenticator子类对象中获取登录的相关信息,故直接使用 * Transport 抽象类中静态 send()
          * 方法来简化代码编写
          */
 
         Transport.send(message);
 
     }
 
     public static void main(String[] args) throws Exception {
         SendMailAuthenticator send = new SendMailAuthenticator();
         Authenticator auth = new GUIAuthenticator();
         send.sendMail(auth);
     }
 }

3、  通过邮件认证接受邮件
package com.mail;
 import java.util.*;
 import javax.mail.*;
 import javax.mail.internet.*;
 
 /**
  * 通过邮件认证接收邮件
  * @author sam
  *
  */
 public class RevMailAuthenticator {
     //邮件服务器地址
     private String smtpServer = "pop.qq.com";
 
     public void sendMails(Authenticator auth) throws Exception {
         // 设置协议、是否身份验证、服务器等信息
         Properties props = new Properties();
         props.setProperty("mail.transport.protocol", "pop3");
         props.setProperty("mail.smtp.auth", "true");
         props.setProperty("mail.host", smtpServer);
         // 通过传入的参数获得Authenticator子类对象
         Session session = Session.getInstance(props, auth);
         /***********************************************************************
          * 由于Session对象中注册了Authenticator子类对象,因此可以直接
          * 
          * 从该Authenticator子类对象中获取登录的相关信息,故直接使用
          * 
          * store.connect();而不用传递用户名和密码参数
          */
         Store store = session.getStore("pop3");
         //连接pop.qq.com邮件服务器
         store.connect();
         //返回文件夹对象
         Folder folder = store.getFolder("INBOX");
         //设置仅读
         folder.open(Folder.READ_ONLY);
         //获取信息
         Message message[] = folder.getMessages(); 
         for(int i=message.length-1; i>0; i--) {
             //打印主题
             System.out.println(message[i].getSubject());
             System.out.println("-----------------------------------------");
         }
         folder.close(true);
         store.close();
     }
 
     // 测试
     public static void main(String[] args) throws Exception {
         RevMailAuthenticator sender = new RevMailAuthenticator();
         // 这里体现了使用策略模式的好处,客户端可以选择使用
         // 具体的哪一种身份验证方式来提交信息
         //对话框方式输入用户名和密码
         Authenticator auth = new GUIAuthenticator();
         sender.sendMails(auth);
     } 
 }

总结:通过邮件认证的方式连接邮件服务器,程序的通用性好了很多,我们每次运行程序的时候都可以切换不同的用户,程序灵活了很多,而且不用修改代码就可以重用。其实Authenticator是设计模式的一种,Authenticator 的具体子类来实现不同的身份验证方式,这样使得用户可以通过不同的登录方式来登录,现实中也是这样的。

 

如果教程哪里写得不对,或者有什么疑问可以留言给我,我会帮你解答!



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值