【问题标题】:Problem connecting to Python mail server from Java Camel application从 Java Camel 应用程序连接到 Python 邮件服务器的问题
【发布时间】:2020-04-29 15:19:14
【问题描述】:

我有一个使用 Python 语言 aiosmtpd 包 (https://github.com/aio-libs/aiosmtpd) 实现的简单电子邮件服务器。我还有一个 Apache Camel 应用程序,其路由尝试从服务器获取邮件。

我已经能够成功地将邮件发送到服务器,并且它正在被保存到一个目录中。但是,我在尝试从服务器获取邮件时遇到了问题。来自 Camel 应用程序的错误消息是:

2020-04-29 10:51:54.476  WARN 17916 --- [/localhost:8025] o.a.c.c.m.MailConsumer                   : Consumer Consumer[imap://localhost:8025?delay=10000&unseen=true] failed polling endpoint: imap://localhost:8025?delay=10000&unseen=true. Will try again at next poll. Caused by: [javax.mail.AuthenticationFailedException - failed to connect, no user name specified?]

javax.mail.AuthenticationFailedException: failed to connect, no user name specified?
    at javax.mail.Service.connect(Service.java:373) ~[jakarta.mail-1.6.4.jar:1.6.4]
    at org.apache.camel.component.mail.MailConsumer.ensureIsConnected(MailConsumer.java:568) ~[camel-mail-3.1.0.jar:3.1.0]
    at org.apache.camel.component.mail.MailConsumer.poll(MailConsumer.java:126) ~[camel-mail-3.1.0.jar:3.1.0]
    at org.apache.camel.support.ScheduledPollConsumer.doRun(ScheduledPollConsumer.java:187) [camel-support-3.1.0.jar:3.1.0]
    at org.apache.camel.support.ScheduledPollConsumer.run(ScheduledPollConsumer.java:106) [camel-support-3.1.0.jar:3.1.0]
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) [?:1.8.0_241]
    at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:308) [?:1.8.0_241]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$301(ScheduledThreadPoolExecutor.java:180) [?:1.8.0_241]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:294) [?:1.8.0_241]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) [?:1.8.0_241]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) [?:1.8.0_241]
    at java.lang.Thread.run(Thread.java:748) [?:1.8.0_241]

邮件服务器不显示任何可见消息。我不知道它是否维护某种日志。发送邮件时,服务器会显示很多关于它从发件人那里收到的消息的信息,所以它肯定是在显示一些信息。

我不知道用户名应该是什么。另外,用户是否需要密码?我在 aiosmtpd 网站上找不到涉及用户或密码的信息。

是否期望邮件服务器具有一组已识别/授权的用户,并且我需要指定其中一个?是否存在不需要用户/密码之类的东西?

这里是骆驼路线供参考:

<route id="mail-receive">
  <from
    uri="imap://{{mail-client.server.host}}:{{mail-client.server.port}}?unseen=true&amp;delay=10000" />
  <log loggingLevel="INFO" message="start - mail-receive" />
  <to uri="file:{{mail-client.receive.dest-dir}}" />
  <log loggingLevel="INFO" message="end - mail-receive" />
</route>

这里是邮件服务器 python 脚本:

server.py:

#! /usr/bin/python3

import os
import asyncio
import logging
import tempfile

from aiosmtpd.controller import Controller
from aiosmtpd.handlers import Mailbox


async def mailbox_controller(dir):
    cont = Controller(Mailbox(dir), hostname='', port=8025)
    cont.start()


def main():
    logging.basicConfig(level=logging.DEBUG)

    temp_dir = tempfile.TemporaryDirectory()
    maildir_path = os.path.join(temp_dir.name, 'maildir')

    loop = asyncio.get_event_loop()
    loop.create_task(mailbox_controller(dir=maildir_path))

    try:
        loop.run_forever()
    except KeyboardInterrupt:
        logging.info('Shutting down')


if __name__ == '__main__':
    main()

【问题讨论】:

    标签: python-3.x apache-camel aiosmtpd


    【解决方案1】:

    aiosmtpd 是 SMTP 服务器。 SMTP 协议用于发送、中继或转发消息,但您不能使用它来接收消息。您需要将您的邮箱应用程序与IMAPPOP3 的一些实现结合起来。

    【讨论】:

    • IMAP Camel 路线不应该是这样吗?我想我不明白。你有什么要寻找的例子或建议吗?
    • 在 Camel 中你有 IMAP 客户端。您目前没有在 python 中实现的 IMAP 服务器(您只有 SMTP 服务器),因此 Camel 无法连接。我没有例子。我在这里是因为问题被标记为 apache-camel,但这都是关于你的 python 服务器的。我对 python 生态系统一无所知,因此无法为 IMAP 服务器推荐好的库或示例。
    • 这很有帮助。它向我指出了 SMTP 的作用(并且只指出了它的作用)。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-12-15
    • 1970-01-01
    • 2020-02-09
    • 2015-11-22
    • 1970-01-01
    • 2022-10-21
    • 2020-01-06
    相关资源
    最近更新 更多