0

所以我正在构建一个电子邮件客户端并对我正在连接的服务器进行身份验证,我已经看到这个被使用了很多:

Session session = Session.getInstance(props, new javax.mail.Authenticator() {
        protected PasswordAuthentication getPasswordAuthentication() {
            return new PasswordAuthentication(username, password);
        }
    });

我不能说我已经完全掌握了这段代码是如何工作的,除了它用于登录服务器的某些地方。

有人可以花时间向我解释它是如何工作的吗?

我一直在尝试使用该username值,所以我不必将它存储在我的Properties文件中,但我无法实例化它,也找不到任何 get 方法。

任何帮助表示赞赏!

4

1 回答 1

0

最好的解释是您几乎不需要该代码。它是非常、非常、非常旧的 JavaMail 版本遗留下来的,每个人都只是不断地复制和粘贴该代码,因为没有人知道如何从头开始编写代码。

更长的解释是,Authenticator 只是 JavaMail 向应用程序询问用户名和密码的一种方式,它允许应用程序向用户询问用户名和应用程序。在简单的情况下,不涉及“询问”,一切都是静态的,而 Authenticator 只是一个保存用户名和密码并在调用时返回它们的类。这就是上面代码中发生的情况,其中作为 Authenticator 子类的匿名内部类定义了一个方法,该方法返回包含用户名和密码的 PasswordAuthentication“结构”。

于 2020-01-14T02:44:16.560 回答