2017-08-07 21 views
0

私はこの頭を抱かせることができないという厄介なエラーがあります。今かなり長い間それを解決しようとしてきました。どんな助けも非常に憂慮されるでしょう。私はスタックトレースを貼り付けます、私はまた、Wiresharkでいくつかのデバッグを行ったと私は同様に投稿します。Django sendmail SSLエラープロトコル違反でEOFが発生しました

私は、成功せずにssl通信に関連する可能性のあるpythonパッケージをアップグレードしようとしました。この問題は、EMAIL_USE_TLSがTrueで、デバッグモードとプロダクションの両方で発生した場合にのみ発生します。私はまず、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

事前にお手数をおかけしていただきありがとうございます!

答えて

0

証明書に何か問題がありました.PHPサーバーをホストしている会社で、Pythonや一部のPHPモジュールで問題が発生しています。私はそれが私が持っているopenSSLバージョン(OpenSSL 1.0.2j)で何かでなければならないと思う。とにかく解決されたので、このスレッドは閉じられます。

他の誰かがこの問題の原因となった場合は、SMTPホスト会社に連絡し、別の中継を提供する可能性があります。

そこにいるすべての開発者にとって幸いです!

関連する問題