1

更新理由を理解しました。Gmailはポート465と587でSMTPサーバーを提供し、465はSSL、587はTLSであり、ESMTPはTLSを必要としているため、sslサーバーである465では機能しません...作品私は、誰かが理由を説明できるのであれば、なぜそれを行うのか明確ではありません:))


SMTPとTwistedを使用して電子メールを送信しようとしていますが、何も起こらず、エラーも出力も電子メールもありません。

出力

MacBookPro:EmailSender User$ python send_mime_email.py 
What is your email address? [REMOVED]@gmail.com
What is your username (typically same as email address)? [REMOVED]@gmail.com
What is your password? [REMOVED]
What is your smtp server details? smtp.gmail.com:465
-------Email Details-------
Subject: Hello
Body: Hi, how are you?
Attachment: FTP_Commands.txt
-------Logging-------
2013-01-20 20:43:44-0500 [-] Log opened.
2013-01-20 20:43:44-0500 [-] Creating email
2013-01-20 20:43:44-0500 [-] Created Message.
2013-01-20 20:43:44-0500 [-] Starting factory <twisted.mail.smtp.ESMTPSenderFactory instance at 0xa3c508>
2013-01-20 20:43:44-0500 [-] Sending Email
2013-01-20 20:53:44-0500 [ESMTPSender,client] SMTP Client retrying server. Retry: 5
^C2013-01-20 20:54:47-0500 [-] Received SIGINT, shutting down.
2013-01-20 20:54:47-0500 [ESMTPSender,client] SMTP Client retrying server. Retry: 4
2013-01-20 20:54:47-0500 [-] Main loop terminated.

コード

import sys
import email
import email.mime.application

import sys

from OpenSSL.SSL import SSLv3_METHOD

from twisted.mail.smtp import ESMTPSenderFactory
from twisted.internet.ssl import ClientContextFactory
from twisted.internet.defer import Deferred
from twisted.internet import reactor
from twisted.python import log

try:
    from cStringIO import cStringIO as StringIO
except ImportError:
    from StringIO import StringIO


def create_email(address, subject, body, data):
    print "Creating email"
    # email block

    # text body
    msg = email.mime.Multipart.MIMEMultipart()
    msg['Subject'] = subject

    # send it to ourselves to make it simple
    msg['From'] = address
    msg['To'] = address

    # body
    body = email.mime.Text.MIMEText(body)
    msg.attach(body)
    att = email.mime.application.MIMEApplication(data, _subtype="binary")
    att.add_header('Content-Disposition','attachment',filename="data.bin")
    msg.attach(att)

    print "Created Message."

    # Create a context factory which only allows SSLv3 and does not verify
    # the peer's certificate.
    return str(msg)

def send_email(smtp_server, smtp_port, username, password, from_, to, msg):


    contextFactory = ClientContextFactory()
    contextFactory.method = SSLv3_METHOD

    resultDeferred = Deferred()

    mime_obj = StringIO(str(msg))

    senderFactory = ESMTPSenderFactory(
                                       username,
                                       password,
                                       from_,
                                       to,
                                       mime_obj,
                                       resultDeferred,
                                       contextFactory=contextFactory)

    reactor.connectTCP(smtp_server, smtp_port, senderFactory)
    print "Sending Email"
    return resultDeferred



if __name__ == '__main__':
    email_address = raw_input("What is your email address? ")
    username      = raw_input("What is your username (typically same as email address)? ")
    password      = raw_input("What is your password? ")
    sd            = raw_input("What is your smtp server details? ")
    ss, sp        = sd.split(":")
    sp            = int(sp)
    print "-------Email Details-------"
    subject = raw_input("Subject: ")
    body    = raw_input("Body: ")
    attachment_file = raw_input("Attachment: ")
    o = open(attachment_file, "rb")
    data = o.read()
    o.close()
    print "-------Logging-------"

    log.startLogging(sys.stdout)
    email_data = create_email(email_address, subject, body, data)
    send_email(ss, sp, username, password, email_address, email_address, email_data)
    reactor.run()
4

2 に答える 2

1

ここには、紛らわしい、トリッキーで紛らわしい用語がいくつかあると思います。「SSL」と「TLS」は、実際には同じものの異なる名前として最も一般的に使用されます。語彙については少し厳密ですが(おそらく技術的にはまだ完全に正しいわけではありません)、「SSLv2」という名前のプロトコルと「SSLv3」(SSLv2へのアップデート)という名前の別のプロトコルと「TLSv1」(SSLv3へのアップデート)という名前の別のプロトコルがあります。

多くの人が「SSL」とは、これら3つのことのいずれか、またはおそらくすべてを指すと言います。

また、多くの人が「TLS」と言って、これら3つのことのいずれか、またはおそらくすべてを指します。

また、いくつかの(暗号化されていない)データを交換するためにすでに使用されている確立された接続で、これらのプロトコルの1つを話し始めるという別の概念があります。時々それは人々が「TLS」と言うときの意味です、それはあなたがあなたの質問の一番上で「TLS」と言うときあなたが意味することです。

Gmailがポート465で提供するのは、接続の最初、つまりSMTPトラフィックが交換される前に開始する必須のSSL(SSLv2、SSLv3、またはTLSv1のいずれか)を備えたSMTPサーバーです。

Gmailがポート587で提供するのは、SSL(SSLv2、SSLv3、またはTLSv1のいずれか)のないSMTPサーバーですが、後でSSLをオンにするスイッチをネゴシエートするためのSMTP機能をサポートします。

もちろん、クライアントに関する限り、ここでの違いは、TCP接続が確立されたらすぐにSSL(SSLv2、SSLv3、またはTLSv1)を開始するか、代わりにSMTPを話し始めて、後でネゴシエートするかです。 SSL(SSLv2、SSLv3、またはTLSv1)に「アップグレード」します。

クライアントとサーバーがここで正確に何が起こるかについて意見が一致しない場合、結果は「ハング」接続になる可能性があります。たとえば、サーバーはクライアントがSSLハンドシェイクを開始するのを待機し、クライアントはサーバーがSMTPを送信するのを待機します。挨拶。

于 2013-01-22T21:44:17.137 に答える
0

問題は、smtp.gmail.com:587ではなくsmtp.gmail.com:465を使用していたことで解決しました。

于 2013-01-21T03:55:45.947 に答える