0

我是 asyncio / aiosmtpd 的新手。我使用这个错误,还是这是一个错误?

运行下面的代码,我收到一个错误,表明我们将字节与字符串混淆了。我在带有 aiosmtpd 1.0a5 的 Linux 上使用 Python 3.6.1 运行它。

#!/usr/bin/env python3
import asyncio
from aiosmtpd.controller import Controller
from aiosmtpd.handlers import Proxy
import logging


async def proxy_mail(loop):
    cont = Controller(
        Proxy('localhost', 8025),
        hostname='localhost',
        port=1025)
    cont.start()


def main():
    logging.basicConfig(level=logging.DEBUG)
    loop = asyncio.get_event_loop()
    loop.create_task(proxy_mail(loop=loop))
    loop.run_forever()


if __name__ == '__main__':
    main()

我得到了这个回溯。

Traceback (most recent call last):
  File "/home/magnusl/.pyenv/versions/3.6.1/lib/python3.6/site-packages/aiosmtpd/smtp.py", line 235, in _handle_client
    yield from method(arg)
  File "/home/magnusl/.pyenv/versions/3.6.1/lib/python3.6/site-packages/aiosmtpd/smtp.py", line 585, in smtp_DATA
    status = yield from self._call_handler_hook('DATA')
  File "/home/magnusl/.pyenv/versions/3.6.1/lib/python3.6/site-packages/aiosmtpd/smtp.py", line 187, in _call_handler_hook
    status = yield from hook(self, self.session, self.envelope, *args)
  File "/home/magnusl/.pyenv/versions/3.6.1/lib/python3.6/asyncio/coroutines.py", line 210, in coro
    res = func(*args, **kw)
  File "/home/magnusl/.pyenv/versions/3.6.1/lib/python3.6/site-packages/aiosmtpd/handlers.py", line 101, in handle_DATA
    if NLCRE.match(line):
TypeError: cannot use a string pattern on a bytes-like object

如果我在 aiosmtpd/handlers.py 中的 Proxy 类中更改它:

@asyncio.coroutine
def handle_DATA(self, server, session, envelope):
    lines = envelope.content.splitlines(keepends=True)

对此

@asyncio.coroutine
def handle_DATA(self, server, session, envelope):
    lines = str(envelope.content).splitlines(keepends=True)

它似乎有效,但我对信封、邮件协议、编码等知之甚少,不知道这是否是一个适当的修复,或者即使我正在使用图书馆。在我看来,这个处理程序永远无法工作,我认为有一些测试......

4

1 回答 1

0

事实上,这是 aiosmtpd 1.0a5 中的一个错误(也在这个问题中报告过)。它被报告并随后修复(v1v2)。

aiosmtpd 1.0b1 最近发布了此修复程序。请尝试升级——我在两个版本上都尝试了你的脚本,但在 1.0a5 上都失败了,在 1.0b1 上成功了。

于 2017-05-09T21:21:45.050 回答