一、问题描述
1、问题现象
通过System.Net.Mail.SmtpClient
使用SSL/TLS协议发送邮件失败并报错
System.Net.Mail.SmtpException: Failure sending mail
详细报错信息:
System.Net.Mail.SmtpException: Failure sending mail.
---> System.IO.IOException: Unable to read data from the transport connection: The connection was closed.
at System.Net.Mail.SmtpReplyReaderFactory.ProcessRead(Byte[] buffer, Int32 offset, Int32 read, Boolean readLine)
at System.Net.Mail.SmtpReplyReaderFactory.ReadLines(SmtpReplyReader caller, Boolean oneLine)
at System.Net.Mail.SmtpReplyReaderFactory.ReadLine(SmtpReplyReader caller)
at System.Net.Mail.SmtpConnection.GetConnection(String host, Int32 port)
at System.Net.Mail.SmtpTransport.GetConnection(String host, Int32 port)
at System.Net.Mail.SmtpClient.GetConnection()
at System.Net.Mail.SmtpClient.Send(MailMessage message)
--- End of inner exception stack trace ---
at System.Net.Mail.SmtpClient.Send(MailMessage message)
2、问题原因
这个问题跟SSL/TLS的协议版本有关系,SSL演化到3.0之后还是不够安全,因此又出现了SSL的升级版TLS协议,由于建立连接时的区别又分别被称为显示SSL和隐式SSL。SSL/TLS协议通常是结对出现SSL/TLS,不过大家还是喜欢简称为SSL。
目前最新版本是TLS 1.3,其他可用版本是TLS 1.2和TLS 1.1,其中TLS1.1计划于2020年弃用
所以,目前主流的邮箱服务商加密协议使用的都是TLS。
但是System.Net.Mail.SmtpClient
不支持较新的TLS协议,具体的TLS协议版本支持情况MSDN上并未找到相关说明
截止到2020年3月受影响的框架版本:
- .NET Core 2.0-3.1
- .NET Framework 2.0-4.8
目前微软MSDN已经将System.Net.Mail.SmtpClient
标记为已过期(obsolete),但源码中并未标记,也并未给出替代实现。
二、解决办法
1、使用System.Web.Mail
System.Web.Mail.SmtpMail
虽然已被标记为已过期,但是毕竟他支持新的SSL/TLS协议。
不过,需要注意的是,System.Web.Mail.SmtpMail
,只适用于 .NET Framework(>=2.0)
示例代码:
using System.Web.Mail;
using System;
namespace Ken.IO.Util {
class Program
{
public static void Main (string[] args)