python - 使用 ESMTP 和 Twisted to GMail 发送电子邮件就在那里(没有错误或任何东西)

标签 python smtp gmail twisted

更新 找出原因,gmail 在端口 465 和 587 上提供 smtp 服务器,465 是 SSL,587 是 TLS,而 ESMTP 需要 TLS,这就是为什么它不能与 465(ssl 服务器)一起使用的原因...我认为(我确实知道它有效,我只是不确定为什么如果有人可以解释为什么请这样做:))

<小时/>

我尝试使用 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()

最佳答案

我认为,这里有一些棘手、令人困惑的术语使事情变得困惑。 “SSL”和“TLS”实际上最常用作同一事物的不同名称。对词汇稍微严格一点(也许在技术上仍然不是绝对正确),有一个名为“SSLv2”的协议(protocol)、另一个名为“SSLv3”的协议(protocol)(SSLv2 的更新)和另一个名为“TLSv1”的协议(protocol)(SSLv3 的更新)。

许多人说“SSL”是指这三件事中的任何一个,或者可能是全部。

此外,许多人说“TLS”是指这三件事中的任何一个,或者可能是全部!

此外,还有一个单独的概念,即开始在已建立的连接上使用这些协议(protocol)之一,该连接已已经用于交换一些(非加密)数据。有时就是人们说“TLS”时的意思,这就是您在问题顶部说“TLS”时的意思。

gmail 在端口 465 上提供的是带有强制 SSL(SSLv2、SSLv3 或 TLSv1,我没有检查是哪一个)的 SMTP 服务器,该服务器从连接一开始就开始 - 即在任何 SMTP 流量被访问之前。已交换。

gmail 在端口 587 上提供的是不带任何 SSL(SSLv2、SSLv3 或 TLSv1 中的任何一种)的 SMTP 服务器,但支持 SMTP 功能,用于协商开关以在某个时刻打开 SSL稍后。

当然,就客户端而言,这里的区别在于,他们是否应该在建立 TCP 连接后立即启动 SSL(SSLv2、SSLv3 或 TLSv1),或者是否应该开始使用 SMTP,然后也许稍后协商“升级”到 SSL(SSLv2、SSLv3 或 TLSv1)。

如果客户端和服务器不同意这里到底应该发生什么,结果可能是“挂起”连接 - 例如,服务器等待客户端开始 SSL 握手,而客户端等待服务器发送它是 SMTP 问候语。

关于python - 使用 ESMTP 和 Twisted to GMail 发送电子邮件就在那里(没有错误或任何东西),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14431517/

相关文章:

使用 Postman 发送 Gmail api

python - 在运行时修改函数代码

字符串中间的 Python 通配符

python套接字如何不对连接请求进行排队

Java 邮件无法使用 tls 或 ssl 连接到 smtp

python - 如何在 Yagmail 中插入图片? (Python)

linux - Mailx 和 Gmail nss 配置目录

python - 如何提取字符串中整数值的第二个实例

java - 无法使用 OAuth 2 通过 Jakarta Mail 连接到 Office 365 SMTP 服务器

php - 为我的本地 Web 应用程序尝试访问 google.com 时出错