先表明Outlook的参数:网址:https://support.office.com/zh-cn/article/Outlook-com-%E7%9A%84-POP%E3%80%81IMAP-%E5%92%8C-SMTP-%E8%AE%BE%E7%BD%AE-d088b986-291d-42b8-9564-9c414e2aa040
POP 访问是被默认禁用的。 若要启用 POP 访问,请参阅在 Outlook.com 中启用 POP 访问。
IMAP 服务器名称outlook.office365.com
IMAP 端口 993
IMAP 加密方法TLS
POP 服务器名称outlook.office365.com
POP 端口 995
POP 加密方法 TLS
SMTP 服务器名称smtp.office365.com
SMTP 端口 587
SMTP 加密方法 STARTTLS
安装nuget包:因为使用的core项目,所以引用了ReturnTrue.AspNetCore.Net.SmtpClient包(SmtpClient)。
官方指定代码:
Yes, I am using SMTP client submission. This is the c# code: var smtpClient = new SmtpClient() { Host = "smtp.office365.com", Port = 587, UseDefaultCredentials = false, EnableSsl = true }; smtpClient.Credentials = new NetworkCredential("*** 发送邮箱账号 ***", "密码"); var message = new MailMessage { From = new MailAddress("*** 发送邮箱账号 ***"), Sender = new MailAddress("*** 接收邮箱账号 ***"), Subject = "Test mail", IsBodyHtml = false }; message.To.Add("*** 接收邮箱账号 ***"); message.Body = "This is a test mail. "; smtpClient.Send(message);
上述代码运行无误,因为一开始没有找到该代码,导致写的代码出现以下异常:
Message=The SMTP server requires a secure connection or the client was not authenticated. The server response was: 5.7.57 SMTP; Client was not authenticated to send anonymous mail during MAIL FROM [HK0P153CA0010.APCP153.PROD.OUTLOOK.COM]
源代码:这是我之前写的代码,实际上是一样的,但是一开始一直报上述错误(原因就是在绑定账号密码前要设置UseDefaultCredentials = false)
string smtpServer = "smtp.office365.com"; int smtpPort = 587; string mailFrom = "xxx@outlook.com"; string passWord = "xxxxxx"; string mailTo = "xxxx@qq.com"; SmtpClient smtpClient = new SmtpClient(smtpServer, smtpPort); smtpClient.UseDefaultCredentials = false;//写到这里不报错 smtpClient.Credentials = new NetworkCredential(mailFrom, passWord); smtpClient.EnableSsl = true; //smtpClient.UseDefaultCredentials = false;//写到这里会报错,必须在账号密码绑定前写。 MailAddress mailAddressFrom = new MailAddress(mailFrom); MailAddress mailAddressTo = new MailAddress(mailTo, "xx的QQ邮箱"); MailMessage mailMessage = new MailMessage(mailAddressFrom, mailAddressTo); mailMessage.Subject = "用c#测试发送邮件"; mailMessage.Body = "这是一次测试发送,发送人用的outlook邮箱"; mailMessage.BodyEncoding = Encoding.UTF8; smtpClient.Send(mailMessage);
代码很短,单想到实例化对象的顺序还会产生这样的结果,以后要注意了。
后续事项:域名未设置 SPF 解析记录
漏洞描述
SPF 记录是一种域名服务(DNS)记录,用于标识哪些邮件服务器可以代表您的域名发送电子邮件。 SPF 记录的目的是为了防止垃圾邮件发送者在您的域名上,使用伪造的发件人地址发送邮件。
若您未对您的域名添加 SPF 解析记录,则黑客可以仿冒以该域名为后缀的邮箱,来发送垃圾邮件。
修复方案
在您的 DNS 服务提供商处,为您的域名添加一条 TXT 记录:
-
将主机字段(Host)设置为您子域名的名称。(例如,如果您的电子邮件地址是
contact@mail.example.com
,则为mail
。)如果不使用子域名,则将其设为@
。 -
用您的 SPF 记录填写 TXT 值字段。例如
v=spf1 a mx include:secureserver.net ~all
- 对应的阿里云方案链接:https://help.aliyun.com/knowledge_detail/37532.html?spm=5176.13394938.0.0.79dc2e17bQeEkN 它那个txt值包含中文符号,有点问题