C# 发送邮件方法 C#如何使用SmtpClient发送邮件

发布时间 - 2026-01-24 00:00:00    点击率:
SmtpClient 已被微软标记为过时,推荐改用 MailKit:支持异步、OAuth2、STARTTLS 自动协商及详细错误反馈;若必须用内置 API,仅限 net6.0-windows 以上且需正确配置端口与凭据;Gmail/Outlook 等须使用应用专用密码或 OAuth2。

SmtpClient 已被标记为过时,别再用它了

从 .NET Core 2.0 和 .NET 5+ 开始,SmtpClient 类已被微软明确标记为 Obsolete,官方文档写明“不推荐用于新开发”。它缺少对现代 SMTP 认证(如 OAuth2)、异步支持不完整、API 设计僵硬,且无法处理 STARTTLS 升级失败等真实场景。强行沿用会导致部署时警告、未来版本移除风险,以及难以调试的连接超时或认证失败。

改用 MailKit:SendAsync + OAuth2 + 真实错误反馈

目前最稳妥的替代方案是 MailKit(NuGet 包:MailKit),它原生支持异步、SASL 认证(含 Microsoft Graph OAuth2)、STARTTLS 自动协商、详细异常信息(比如告诉你具体卡在 AUTH LOGIN 还是 RCPT TO 阶段)。

常见使用要点:

  • SmtpClient.ConnectAsync() 必须显式调用,不能跳过;端口需匹配加密方式(如 587 + SecureSocketOptions.StartTls
  • 用户名不是邮箱全名 —— 某些服务商(如 Outlook/Hotmail)要求用 client.AuthenticateAsync("username", "password") 中的 username 是不含 @domain 的短名(例如 user123 而非 user123@outlook.com
  • 发件人地址必须与认证账户一致,否则多数 SMTP 服务(Gmail、Outlook)会静默拒绝
  • 附件路径若含中文或空格,务必用 new MimePart("application/octet-stream") { ContentObject = new ContentObject(File.OpenRead(path), ContentEncoding.Default) } 手动加载,避免 MimeKit 内部路径解析失败
var message = new MimeMessage();
message.From.Add(new MailboxAddress("Me", "me@example.com"));
message.To.Add(new MailboxAddress("You", "you@example.com"));
message.Subject = "Hello";
message.Body = new TextPart("plain") { Text = "Hi there!" };

using var client = new SmtpClient();
await client.ConnectAsync("smtp.gmail.com", 587, SecureSocketOptions.StartTls);
await client.AuthenticateAsync("me@example.com", "app-specific-password"); // 注意:Gmail 必须用应用专用密码
await client.SendAsync(message);
await client.DisconnectAsync(true);

如果必须用内置 API:.NET 6+ 的 SmtpClient 只能降级到兼容模式

某些企业内网 SMTP 服务器只认老协议,或项目受限无法引入第三方包。此时可继续用 System.Net.Mail.SmtpClient,但必须满足:

  • 目标框架必须是 net6.0-windows 或更高(Linux/macOS 下该类完全不可用)
  • 配置 SmtpClient.EnableSsl = true 时,端口必须为 465;设为 false 时端口通常为

    25587,但后者需服务端主动发 STARTTLS 命令(.NET 内置实现对此支持不稳定)
  • SmtpClient.Credentials 必须是 NetworkCredential 实例,传 null 或匿名凭据在绝大多数公网 SMTP 上直接被拒
  • 别依赖 SmtpClient.Send() 的同步阻塞行为 —— 它实际是同步包装异步,线程池易耗尽;务必用 SendMailAsync()(.NET Core 3.0+)并 await

Gmail / Outlook 现在基本不接受密码直连

2025 年起,Google 全面关闭 Gmail 的“允许不够安全的应用”选项;Microsoft 也强制 Outlook.com 使用 OAuth2 或应用专用密码。直接填邮箱密码调用 AuthenticateAsync()Credentials 会稳定返回 AuthenticationFailedException535-5.7.8 Username and Password not accepted

正确做法:

  • Gmail:进 Google 账户 → 安全 → 应用专用密码,生成 16 位密码,替换原密码
  • Outlook:注册 Azure AD 应用,获取 client_idclient_secrettenant_id,用 Microsoft.Identity.Client 获取 access token,再传给 MailKitXOAuth2 认证流程
  • 国内企业邮箱(如腾讯企业邮、阿里云邮件推送):查文档确认是否开放 SMTP,部分仅支持 API 调用(如 POST /send),这时根本不用 SmtpClientMailKit

最容易被忽略的一点:SMTP 连接成功 ≠ 邮件发出成功。很多代码只检查 ConnectAsync 是否抛异常,却没捕获 SendAsync 中的 SmtpCommandException(比如收件人格式错误、附件超限、触发反垃圾策略),导致邮件静默丢失。


# linux  # word  # go  # windows  # app  # access  # 端口  # 腾讯  # ssl  # mac  # 阿里云  # ai  # macos  # NULL  # mail  # Token  # 线程  # default  # 异步  # microsoft  # azure  # outlook 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用Blade模板引擎?(完整语法和示例)  免费网站制作appp,免费制作app哪个平台好?  如何用IIS7快速搭建并优化网站站点?  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  如何安全更换建站之星模板并保留数据?  如何用好域名打造高点击率的自主建站?  高端网站建设与定制开发一站式解决方案 中企动力  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  *服务器网站为何频现安全漏洞?  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  常州企业网站制作公司,全国继续教育网怎么登录?  MySQL查询结果复制到新表的方法(更新、插入)  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  如何在IIS中新建站点并配置端口与物理路径?  如何在VPS电脑上快速搭建网站?  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  高性能网站服务器配置指南:安全稳定与高效建站核心方案  Laravel如何生成URL和重定向?(路由助手函数)  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  移动端脚本框架Hammer.js  详解Android——蓝牙技术 带你实现终端间数据传输  图册素材网站设计制作软件,图册的导出方式有几种?  香港网站服务器数量如何影响SEO优化效果?  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  香港服务器如何优化才能显著提升网站加载速度?  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】  Windows10如何更改计算机工作组_Win10系统属性修改Workgroup  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  如何确保西部建站助手FTP传输的安全性?  JS经典正则表达式笔试题汇总  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  googleplay官方入口在哪里_Google Play官方商店快速入口指南  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何快速搭建虚拟主机网站?新手必看指南  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  iOS验证手机号的正则表达式  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  C#如何调用原生C++ COM对象详解  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  如何在Windows 2008云服务器安全搭建网站?  Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册  JavaScript数据类型有哪些_如何准确判断一个变量的类型  如何正确下载安装西数主机建站助手?  Laravel如何使用.env文件管理环境变量?(最佳实践)