解决阿里云邮件发送不能使用25端口问题

本地测试发邮件功能很流畅,部署到阿里云上以后发现总是NOT FIND,这就很奇怪。开始以为是url写错了导致的,检查N多遍发现完全一毛一样的。后来各种百度,发现是因为阿里云禁用了25端口导致的。查看各种资料,解决的办法五花八门。试了几种解决方案,都解决了问题。现在整理如下:(不用去尝试申请解禁25端口的,可以很认真负责的告诉你,完全没有卵用)

首先,是阿里大大给的官方的解决方案,用SMTP发送邮件:代码如下

# -*- coding:utf-8 -*-
import urllib, urllib2
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.mime.application import MIMEApplication
# 发件人地址,通过控制台创建的发件人地址
username = ‘[email protected]‘
# 发件人密码,通过控制台创建的发件人密码
password = ‘XXXXXXXX‘
# 收件人地址列表,支持多个收件人,最多30个
rcptlist = [‘[email protected]‘, ‘[email protected]‘]
receivers = ‘,‘.join(rcptlist)
# 构建 multipart 的邮件消息
msg = MIMEMultipart(‘mixed‘)
msg[‘Subject‘] = ‘Test Email‘
msg[‘From‘] = username
msg[‘To‘] = receivers
# 构建 multipart/alternative 的 text/plain 部分
alternative = MIMEMultipart(‘alternative‘)
textplain = MIMEText(‘纯文本部分‘, _subtype=‘plain‘, _charset=‘UTF-8‘)
alternative.attach(textplain)
# 构建 multipart/alternative 的 text/html 部分
texthtml = MIMEText(‘超文本部分‘, _subtype=‘html‘, _charset=‘UTF-8‘)
alternative.attach(texthtml)
# 将 alternative 加入 mixed 的内部
msg.attach(alternative)
# 附件类型
# xlsx 类型的附件
xlsxpart = MIMEApplication(open(‘测试文件1.xlsx‘, ‘rb‘).read())
xlsxpart.add_header(‘Content-Disposition‘, ‘attachment‘, filename=Header("测试文件1.xlsx","utf-8").encode())
msg.attach(xlsxpart)
# jpg 类型的附件
jpgpart = MIMEApplication(open(‘2.jpg‘, ‘rb‘).read())
jpgpart.add_header(‘Content-Disposition‘, ‘attachment‘, filename=Header("2.jpg","utf-8").encode())
msg.attach(jpgpart)
# mp3 类型的附件
mp3part = MIMEApplication(open(‘3.mp3‘, ‘rb‘).read())
mp3part.add_header(‘Content-Disposition‘, ‘attachment‘, filename=Header("3.mp3","utf-8").encode())
msg.attach(mp3part)
# 发送邮件
try:
    client = smtplib.SMTP()
    #python 2.7以上版本,若需要使用SSL,可以这样创建client
    #client = smtplib.SMTP_SSL()
    client.connect(‘smtpdm.aliyun.com‘)
    client.login(username, password)
    #发件人和认证地址必须一致
    client.sendmail(username, rcptlist, msg.as_string())
    client.quit()
    print ‘邮件发送成功!‘
except smtplib.SMTPRecipientsRefused:
    print ‘邮件发送失败,收件人被拒绝‘
except smtplib.SMTPAuthenticationError:
    print ‘邮件发送失败,认证错误‘
except smtplib.SMTPSenderRefused:
    print ‘邮件发送失败,发件人被拒绝‘
except smtplib.SMTPException,e:
    print ‘邮件发送失败, ‘, e.message

阿里官方解决方案

官方的当然好用喽,就是写的太详细和复杂了,实在懒得折腾,为了尽可能少的改代码,就放弃了。

下面是两种网友提供的简单的解决方案

这个是简化版的SMTP方式

import smtplib
from email.mime.text import MIMEText

msg_from = ‘[email protected]‘  # 发送方邮箱
passwd = ‘****‘  # 填入发送方邮箱的授权码(填入自己的授权码,相当于邮箱密码)
msg_to = [‘****@qq.com‘,‘**@163.com‘,‘*****@163.com‘]  # 收件人邮箱

subject = "邮件标题"  # 主题
content = "邮件内容,我是邮件内容,哈哈哈"
# 生成一个MIMEText对象(还有一些其它参数)
# _text_:邮件内容
msg = MIMEText(content)
# 放入邮件主题
msg[‘Subject‘] = subject
# 也可以这样传参
# msg[‘Subject‘] = Header(subject, ‘utf-8‘)
# 放入发件人
msg[‘From‘] = msg_from
# 放入收件人
msg[‘To‘] = ‘[email protected]‘
# msg[‘To‘] = ‘发给你的邮件啊‘
try:
    # 通过ssl方式发送,服务器地址,端口
    s = smtplib.SMTP_SSL("smtp.qq.com", 465)
    # 登录到邮箱
    s.login(msg_from, passwd)
    # 发送邮件:发送方,收件方,要发送的消息
    s.sendmail(msg_from, msg_to, msg.as_string())
    print(‘成功‘)
except s.SMTPException as e:
    print(e)
finally:
    s.quit()

方法二:为使用send_mail模块发送(和我原来的代码相似,改动较少,墙裂推荐)

setting.py配置如下

# EMAIL_BACKEND = ‘django.core.mail.backends.smtp.EmailBackend‘

EMAIL_HOST = ‘smtp.qq.com‘  # 如果是 163 改成 smtp.163.com
EMAIL_PORT = 465    # 端口号
EMAIL_HOST_USER = ‘[email protected]‘  # 发送者的邮箱帐号
EMAIL_HOST_PASSWORD = ‘***‘  #   发送者的邮箱授权
DEFAULT_FROM_EMAIL = EMAIL_HOST_USER
#这样收到的邮件,收件人处就会这样显示
#DEFAULT_FROM_EMAIL = ‘lqz<‘[email protected]>‘

EMAIL_USE_SSL = True   #使用ssl

#EMAIL_USE_TLS = False # 使用tls
#EMAIL_USE_SSL 和 EMAIL_USE_TLS 是互斥的,即只能有一个为 True

views.py

rom django.core.mail import send_mail   # 导入邮箱模块
from threading import Thread     # 导入线程模块
from threading import Thread
  t1 = Thread(target=send_mail,args=(
  ‘您的%s文章被%s评论了‘%(article_name,user_name),
  ‘这个人评论了:%s‘%(content),
  settings.EMAIL_HOST_USER,
  [‘[email protected]‘] ))   t1.start()

原文地址:https://www.cnblogs.com/ppzhang/p/10305517.html

时间: 2024-10-08 03:04:37

解决阿里云邮件发送不能使用25端口问题的相关文章

阿里云服务器 发送邮箱 STMP 25端口 465端口问题 Javamail 25被禁用

我们传统使用的比较简单的是 STMP 25端口收发邮件 今天发现刚购买的阿里云服务器不能作为客户端通过STMP 25端口发送邮件 开始在网上有说发现是JDK1.8的原因,然后自己也把JDK1.8换到了JDK1.7 还是不行,所以这里排除了JDK的原因. 那么问题来了,是否25端口不能连接适用喃? 然后在终端输入命令行 ,可测试25端口是否可连接. telnet smtp.163.com 25 返回成功 说明你的服务器 是没有封掉25端口的.上面的图是我自己的电脑,当然能连通. 当换到服务器测试的

阿里云 邮件发送(Python)

#coding:utf8 from smtplib import SMTP_SSL from email.header import Header from email.mime.text import MIMEText mail_info = { "from": "", "to": "", "host": "smtp.qq.com", "username": &qu

用ASP.NET Core 1.0中实现邮件发送功能-阿里云邮件推送篇

在上篇中用MailKit实现了Asp.net core 邮件发送功能,但一直未解决阿里云邮件推送问题,提交工单一开始的回复不尽如人意,比如您的网络问题,您的用户名密码不正确等,但继续沟通下阿里云客户还是很耐心的. 最终结论,是由于MailKit发送了两次EHLO命令,查看了MailKit源码后竟然发现,里面写了硬编码: if (host != "smtp.strato.de" && host != "smtp.sina.com") Ehlo (can

解决.NET Core中MailKit无法使用阿里云邮件推送服务的问题

在博问中(.net core怎么实现邮件发送)知道了MailKit无法使用阿里云邮件推送服务发送邮件的问题,自已实测也遇到同样的问题,而用自己搭建的邮件服务器没这个问题. 于是,向阿里云提交了工单...在提供了TCP抓包数据后,阿里云技术专员发现了问题所在:在认证通过后,MailKit发送了EHLO命令,然后才发送MAIL FROM命令,服务器在收到EHLO时会重置客户端的认证状态,所以后续的命令过来时,服务器认为客户端没有认证,于是报错“503 Bad sequence of commands

【初码干货】使用阿里云邮件推送服务架设自己邮件验证与推送体系

提示:阅读本文需提前了解的相关知识 1.电子邮件协议(http://baike.baidu.com/view/2367542.htm) 2.阿里云邮件推送(https://www.aliyun.com/product/directmail) 3.EDM(电子邮件营销)(http://baike.baidu.com/subview/1212416/8602812.htm) 4.SendCloud邮件服务(http://sendcloud.sohu.com/) 阅读目录结构 引: 一.需求分析 二.

阿里云邮件推送服务

提起邮件服务,最早之前一般自建邮件服务器,需要硬软件和运维的支持,稳定性也难保证,随着云服务的普及邮件推送功能的服务化是趋势,也省钱省事省心. 最早开始用过搜狐邮件服务,阿里云生态现在基本都出现了,我们来尝试一下阿里云的邮件推送服务: 一.阿里云控制台操作 首先在阿里云邮件推送控制台添加域名,然后在自己的dns服务器中添加如下的解析(根据控制台中的“配置”): 一个主机名为aliyundm的TXT记录,用于验证域名所有权 一个主机名为空.值为v=spf1 include:spf1.dm.aliy

解决阿里云服务器提示挖矿程序风险

今天大早上收到阿里云邮件通知,提示有挖矿程序.一个激灵爬起来,折腾了一早上,终于解决问题了. 其实前两天就一直收到阿里云的通知,检测到对外攻击,阻断了对其他服务器6379. 6380和22端口的访问,当时没怎么当一回儿事,反正是我用来自己学习用的,就放着不管了,结果今天事态就大了.那就来解决吧. 首先xshell连接服务器,这时候输入命令时明显感觉巨卡. 肯定是cpu被占满了,输入 top -c 命令查看有个进程叫 kworkerds.占用了将近100%的CPU. 这 kworkerds 是个啥

Quartz定时向阿里云MQ发送数据(TCP模式)

针对公司业务逻辑,向阿里云MQ发送指定数据,消费端根据数据来做具体的业务,分两个项目,一个生产端(Producer).一个消费端(Consumer) 生产端通过定时任务执行sql向阿里云MQ发送数据,消费端消费指定Topic上的数据 1:定时任务列表: 2:生产端表结构: aliasName:定时任务别名: cronExpression:定时任务轮询规则: jobGroup:定时任务分组: jobName:定时任务名称: jobTrigger:定时任务触发器: packageUrl:定时任务扫描

解决阿里云OSS跨域问题

解决阿里云OSS跨域问题 现象 本人项目中对阿里云图片请求进行了两次,第一次通过img标签进行,第二次通过异步加载获取.第一次请求到图片,浏览器会进行缓存,随后再进行异步请求,保存跨域失效. 错误信息如下: Failed to load http://cdn.imayuan.com/831ccd4741a7a56d85f6698a21f4ca69.svg: No 'Access-Control-Allow-Origin' header is present on the requested re