因此,我正在构建一个电子邮件客户端,并对要连接的服务器进行身份验证,我已经看到它已经被大量使用:
Session session = Session.getInstance(props, new javax.mail.Authenticator() {
protected PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(username, password);
}
});
我不能说我已经完全掌握了这段代码的工作原理,而不是用来登录服务器的代码。
有人可以花时间向我解释它的工作原理吗?
我一直在尝试使用username
值,因此不必将其存储在我的Properties
文件中,但是我无法实例化它,也找不到任何get方法。
感谢您的任何帮助!
最好的解释是你almost never need that code。它是从非常非常非常旧的JavaMail版本中遗留下来的,每个人都只是继续复制和粘贴该代码,因为没有人知道如何从头开始编写代码。
更长的解释是,Authenticator只是JavaMail向应用程序询问用户名和密码的一种方式,它允许应用程序向用户询问用户名和应用程序。在简单的情况下,不涉及“询问”,所有内容都是静态的,并且Authenticator只是一个类,用于保存用户名和密码,并在调用时返回它们。这就是上面的代码中发生的情况,在上面的代码中,作为Authenticator子类的匿名内部类定义了一个方法,该方法返回包含用户名和密码的PasswordAuthentication“ struct”。