gpt4 book ai didi

python - Django sendmail SSL 错误 EOF 发生违反协议(protocol)

转载 作者:太空宇宙 更新时间:2023-11-03 14:38:27 25 4
gpt4 key购买 nike

我有一个令人讨厌的错误,我无法解决这个问题。已经尝试解决它很长一段时间了。任何帮助将不胜感激。我将粘贴堆栈跟踪,我还使用 Wireshark 进行了一些调试,我也会发布它。

我尝试升级可能与 ssl 通信相关的 python 包,但没有成功。此问题仅在 EMAIL_USE_TLS 为 True 时发生,并且在 Debug模式和生产模式下都会发生。我首先想到可能 SMTP 服务器在旧版本的 ssl 上使用,但事实并非如此。由于 Wireshark 捕获会告诉 ssl 似乎已建立,然后在下一个请求中服务器将意外关闭。

我使用的设置是:

EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'

EMAIL_HOST = 'smtp_server'
EMAIL_PORT = 587
EMAIL_HOST_USER = 'my_username'
EMAIL_HOST_PASSWORD = 'my_password'
EMAIL_USE_TLS = True

发送邮件时我没有做任何奇怪的事情,这是代码:

def email_user(self, subject, message, from_email=None, **kwargs):
return send_mail(subject, message, from_email, [self.email], **kwargs)

错误堆栈跟踪是:

Traceback (most recent call last):
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\handlers\exception.py", line 39, in inner
response = get_response(request)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\handlers\base.py", line 187, in _get_response
response = self.process_exception_by_middleware(e, request)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\handlers\base.py", line 185, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\views\decorators\csrf.py", line 58, in wrapped_view
return view_func(*args, **kwargs)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\views\generic\base.py", line 68, in view
return self.dispatch(request, *args, **kwargs)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\rest_framework\views.py", line 477, in dispatch
response = self.handle_exception(exc)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\rest_framework\views.py", line 437, in handle_exception
self.raise_uncaught_exception(exc)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\rest_framework\views.py", line 474, in dispatch
response = handler(request, *args, **kwargs)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\rest_framework\decorators.py", line 52, in handler
return func(*args, **kwargs)
File "C:\Users\Metadeath\Documents\GitHub\django-dropin\api\views.py", line 18, in register
user = serializer.create(serializer.validated_data)
File "C:\Users\Metadeath\Documents\GitHub\django-dropin\api\serializers.py", line 86, in create
is_sent = user.send_confirmation_email(confirmation_instance=confirmation_instance)
File "C:\Users\Metadeath\Documents\GitHub\django-dropin\users\models.py", line 139, in send_confirmation_email
is_sent = self.email_user(subject, message, from_email) # Returns the number of delivered emails
File "C:\Users\Metadeath\Documents\GitHub\django-dropin\users\models.py", line 132, in email_user
return send_mail(subject, message, from_email, [self.email], **kwargs)
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\mail\__init__.py", line 62, in send_mail
return mail.send()
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\mail\message.py", line 342, in send
return self.get_connection(fail_silently).send_messages([self])
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\mail\backends\smtp.py", line 100, in send_messages
new_conn_created = self.open()
File "C:\Users\Metadeath\Envs\dropin\lib\site-packages\django\core\mail\backends\smtp.py", line 64, in open
self.connection.starttls(keyfile=self.ssl_keyfile, certfile=self.ssl_certfile)
File "c:\users\metadeath\appdata\local\programs\python\python36-32\Lib\smtplib.py", line 770, in starttls
server_hostname=self._host)
File "c:\users\metadeath\appdata\local\programs\python\python36-32\Lib\ssl.py", line 401, in wrap_socket
_context=self, _session=session)
File "c:\users\metadeath\appdata\local\programs\python\python36-32\Lib\ssl.py", line 808, in __init__
self.do_handshake()
File "c:\users\metadeath\appdata\local\programs\python\python36-32\Lib\ssl.py", line 1061, in do_handshake
self._sslobj.do_handshake()
File "c:\users\metadeath\appdata\local\programs\python\python36-32\Lib\ssl.py", line 683, in do_handshake
self._sslobj.do_handshake()
ssl.SSLEOFError: EOF occurred in violation of protocol (_ssl.c:749)

Wireshark capture for client and smtp server when establishing ssl connection

提前感谢您的帮助!

最佳答案

证书有问题,托管 SMTP 服务器的公司在某些 Python 和某些 PHP 模块上确实会出现问题。我怀疑它必须与我拥有的 openSSL 版本(OpenSSL 1.0.2j)有关。现在无论如何都解决了,所以这个线程可能会关闭。

如果其他人遇到此问题,请联系您的 SMTP 托管公司,他们可能会为您提供不同的中继。

祝所有开发者好运!

关于python - Django sendmail SSL 错误 EOF 发生违反协议(protocol),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45555450/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com