C#中收发QQ邮箱电子邮件

1.安装第三方库MailKit

复制代码
#.NET Coredotnet add package MailKit --version 2.5.1
#.NET FrameworkInstall-Package MailKit -Version 2.5.1

2.1发送代码

复制代码
try{    MimeMessage message = new MimeMessage();    message.From.Add(new MailboxAddress("备注", "xxx@qq.com"));//发送邮箱    message.To.Add(new MailboxAddress("备注", "xxx@163.com"));//接收邮箱    message.Subject = "邮件测试标题";//标题    BodyBuilder bodyBuilder = new BodyBuilder();    bodyBuilder.TextBody = "邮件测试正文";    message.Body = bodyBuilder.ToMessageBody();
    //创建SMTP客户端    using (SmtpClient client = new SmtpClient())    {        client.ServerCertificateValidationCallback = (s, c, h, e) => true;        client.Connect("smtp.qq.com", 465, true);//smtp服务器,端口,是否开启ssl        client.Authenticate("xxx@qq.com", "password");//这里的password填授权码        client.Send(message);        client.Disconnect(true);    }}catch (Exception ex){    Console.WriteLine("发送邮件失败:" + ex.Message);}

2.2接收代码

复制代码
try{    //创建IMAP客户端    using (ImapClient client = new ImapClient())    {        client.Connect("imap.qq.com", 993, true);//imap服务器,端口,是否开启ssl        client.Authenticate("xxx@qq.com", "password");//这里的password填授权码        // 打开收件箱        var inbox = client.Inbox;        inbox.Open(FolderAccess.ReadOnly);//只读        // 获取收件箱中的邮件数量        Console.WriteLine("收件箱中共有 {0} 封邮件", inbox.Count);        // 遍历收件箱中的邮件并输出主题        for (int i = 0; i < inbox.Count; i++)        {            var message = inbox.GetMessage(i);            Console.WriteLine("邮件主题:{0}", message.Subject);        }        client.Disconnect(true);    }}catch (Exception ex){    Console.WriteLine("接收邮件失败:" + ex.Message);}

注意:

用户名/帐户: 你的QQ邮箱完整的地址

密码: 生成的授权码

电子邮件地址: 你的QQ邮箱的完整邮件地址

接收邮件服务器: imap.qq.com,使用SSL,端口号993

发送邮件服务器: smtp.qq.com,使用SSL,端口号465或587

获取授权码:

1.登录邮箱

2.【账号与安全】

3.【安全设置-生成授权码】

相关推荐
gnip6 小时前
企业级配置式表单组件封装
前端·javascript·vue.js
一只叫煤球的猫7 小时前
写代码很6,面试秒变菜鸟?不卖课,面试官视角走心探讨
前端·后端·面试
excel8 小时前
Three.js 材质(Material)详解 —— 区别、原理、场景与示例
前端
掘金安东尼8 小时前
抛弃自定义模态框:原生Dialog的实力
前端·javascript·github
hj5914_前端新手12 小时前
javascript基础- 函数中 this 指向、call、apply、bind
前端·javascript
薛定谔的算法12 小时前
低代码编辑器项目设计与实现:以JSON为核心的数据驱动架构
前端·react.js·前端框架
Hilaku12 小时前
都2025年了,我们还有必要为了兼容性,去写那么多polyfill吗?
前端·javascript·css
yangcode12 小时前
iOS 苹果内购 Storekit 2
前端
LuckySusu12 小时前
【js篇】JavaScript 原型修改 vs 重写:深入理解 constructor的指向问题
前端·javascript
LuckySusu12 小时前
【js篇】如何准确获取对象自身的属性?hasOwnProperty深度解析
前端·javascript