c# 收发邮件
话不多说,请看代码:(后面附上项目整体代码,可详细查看。)。
算了,vip文章要评审,还是在这里给朋友们注释一下代码内容吧,方便大家参考使用。
收邮件:
核心代码:
pop3:
//using是个好东西,如果你没有关资源,他自动给你关,特别是对于流来说。pop3其实也是输入流,这里就需要用它来保证一下安全。
using (var client = new Pop3Client()){client.Connect(PopName, PopPort, true); // 使用SSL连接,不用的话最后一个参数改成false。client.Authenticate(MailMS.AccountName, UPwd);//如果是非ssl连接,这里的密码最好也使用邮箱厂商后台可以设置的链接码。这个链接码在邮箱的pop3说明里面有,imap和smtp的说明里面也有。// 获取邮件数量int count = client.GetMessageCount();Console.WriteLine($"Total messages: {count}");// 获取最新的邮件(索引从0开始)for (int i = 0; i < count; i++){string c0 = "", c1 = "", c2 = "";int key = count - 1 - i;var message = client.GetMessage(key);c1 = message.Subject;c0 = message.From.ToString();c2 = message.Date.ToString();dataGridView1.Rows.Add(key + 1, "",c1,c0,c2);//我的页面有个dataGridView来显示邮件列表,所以这里绑一下数据。Hashtable savedMail = new Hashtable();//这个hashtable用来在页面暂存邮件savedMail.Add("Subject", message.Subject);savedMail.Add("From", message.From.ToString());savedMail.Add("Date", message.Date.ToString());savedMail.Add("text", message.TextBody == null ? "" : message.TextBody);savedMail.Add("html", message.HtmlBody == null ? "" : message.HtmlBody);//附件if (message.Attachments.Count() > 0){savedMail.Add("Attachments", message.Attachments);}else{savedMail.Add("Attachments", null);}mails.Add((key + 1).ToString(), savedMail);//暂存所有邮件}}
imap:
//建立连接var client = new ImapClient();if (_ssl == "启用"){client.Connect(MailMS.Imap, MailMS.ImapPort, true); // 替换为你的 IMAP 服务器地址和端口}else {client.Connect(MailMS.Imap, MailMS.ImapPort, false); // 替换为你的 IMAP 服务器地址和端口}client.Authenticate(MailMS.UserName, MailMS.PassWd);client.Inbox.Open(FolderAccess.ReadWrite);打开smtp接口//MailKit.Net.Smtp.SmtpClient smtpClient = new MailKit.Net.Smtp.SmtpClient();//smtpClient.Connect(MailMS.SmtpName, MailMS.SmtpPort, true);注:用户名和密码应妥善保管,不要硬编码到源码中//smtpClient.Authenticate(MailMS.UserName, MailMS.PassWd);//加载分类邮箱AccountHandle acOperate = new AccountHandle();string[] addressInfo = acOperate.GetToAddress("select * from AutoeMailAddress where AccountName='" + MailMS.UserName + "'");string address1 = addressInfo[1];string address2 = addressInfo[2];string address3 = addressInfo[3];string address4 = addressInfo[4];//获取每一个邮件,保存到本地,同时转发,转移完后将邮件标记为已读,int size = 0;int uidCount = 0;int lastPage = 0;var query = SearchQuery.NotSeen;var uids = client.Inbox.Search(query);uidCount = uids.Count();lastPage = lastPage + uidCount;var inbox = client.Inbox;foreach (var uid in uids){if (!IsMove){//停止进程break;}//获取邮件var oldmail = inbox.GetMessage(uid);var flags = inbox.AcceptedFlags;var isRead = oldmail.Headers;string subject = oldmail.Subject;WriteStatus("开始转移标题为“" + subject + "”的邮件……");EmailData data = new EmailData();data.Subject = subject;//邮箱设置AccountInfo account = new AccountInfo();account.UserName = MailMS.UserName;account.PassWd = MailMS.PassWd;account.SmtpName = MailMS.SmtpName;account.SmtpPort = MailMS.SmtpPort;account.MailAddress = MailMS.MailAddress;if (subject.ToLower().Contains("class1")){data.To = address1;}else if (subject.ToLower().Contains("class2")){data.To = address2;}else if (subject.ToLower().Contains("class3")){data.To = address3;}else{data.To = address4;}data.From = MailMS.MailAddress;data.TextBody = oldmail.TextBody;data.HtmlBody = oldmail.HtmlBody;//附件data.Files = null;Hashtable Mail = new Hashtable();Mail.Add("Attachments", oldmail.Attachments);//发送邮件EmailHelper.SendEmailWait(data, Mail, account);//等待5秒,避免服务器认为是攻击await Task.Delay(5000);//发送完毕WriteStatus("邮件“" + subject + "”转移完毕");//将此邮件标记为已读client.Inbox.AddFlags(uid, MessageFlags.Seen, true);size++;}if (!IsMove){WriteStatus("强制停止转移,邮件转移完毕,总共处理了" + size + "封邮件");}else{WriteStatus("邮件转移完毕,总共处理了" + size + "封邮件");}//smtpClient.Disconnect(true);client.Disconnect(true);
发邮件:
核心代码:
smtp:
/// <summary>/// 带了本地的文件和转发的文件/// </summary>/// <param name="data"></param>/// <param name="mail"></param>public static async void SendEmail(EmailData email, Hashtable mail, AccountInfo account){try{// 创建一个新的 MIME 消息对象var message = new MimeMessage();// 设置发件人message.From.Add(MailboxAddress.Parse(email.From));// 设置收件人message.To.Add(MailboxAddress.Parse(email.To));// 设置主题message.Subject = email.Subject;// 创建邮件正文var builder = new BodyBuilder();builder.TextBody = email.TextBody;builder.HtmlBody = email.HtmlBody;// 添加附件if (email.Files != null && email.Files.Count > 0){for (int i = 0; i < email.Files.Count; i++){using (var stream = new FileStream(email.Files[i].ToString(), FileMode.Open)){builder.Attachments.Add(email.Files[i].ToString(), stream);}}}//如果转发的邮件有附件,把附件加上if (mail != null){IEnumerable<MimeEntity> list = (IEnumerable<MimeEntity>)mail["Attachments"];foreach (MimeEntity item in list){builder.Attachments.Add(item);}}// 设置正文message.Body = builder.ToMessageBody();// 使用 SMTP 客户端发送邮件using (var client = new SmtpClient()){//await client.ConnectAsync("smtp.qq.com", 465, true);await client.ConnectAsync(account.SmtpName, account.SmtpPort, true);// 注:用户名和密码应妥善保管,不要硬编码到源码中//await client.AuthenticateAsync("33072340@qq.com", "lctzfpbaxgdpbhih");await client.AuthenticateAsync(account.MailAddress, account.PassWd);// 发送邮件await client.SendAsync(message);// 断开与服务器的连接await client.DisconnectAsync(true);}//Console.WriteLine("邮件已成功发送!");}catch (Exception ex){throw ex;//Console.WriteLine($"邮件发送失败:{ex.Message}");}}
完整代码下载:
https://download.csdn.net/download/axe6404/90438801
相关文章:
c# 收发邮件
话不多说,请看代码:(后面附上项目整体代码,可详细查看。)。 算了,vip文章要评审,还是在这里给朋友们注释一下代码内容吧,方便大家参考使用。 收邮件: 核心代码&#x…...
springboot设置多环境配置文件
实际开发过程中会涉及多个环境,比如dev(开发环境),test(测试环境),prod(线上环境),不同环境下,端口号、数据库地址、redis地址等等会不尽相同,为了避免每次上线到不同环境都要修改配置文件可以在项目中配置…...
智能文档解析与语义分割:LlamaIndex 节点解析器模块全解
节点解析器模块 - LlamaIndex 文件内容的节点解析器 有几种基于文件的节点解析器,它们会根据解析的内容类型(JSON、Markdown 等)创建节点。 最简单的流程是将 FlatFileReader 与 SimpleFileNodeParser 结合使用,自动为每种内容类型选择最佳节点解析器。然后,可以将基于…...
Qt的坐标
一、介绍 控件的坐标是相对于父控件的,如果没有父控件,坐标就相当于桌面。 这是 Qt 坐标系: 二、坐标使用 坐标通过控件对象的 move 函数实现,move(int, int) 一个参数是 x,一个是 y,单位是像素。 代码…...
redis序列化设置
redis序列化设置 redis序列化设置序列化对象里有org.joda.time.DateTime1)、报错内容如下2)、解决方案:分别自定义时间的序列化和反序列化,以对象形式关联到redisTemplate redis序列化设置 redis序列化设置,通过自定义…...
Linux:进程概念
目录 1 冯诺依曼体系 2 操作系统(Operator System) 3 如何理解管理 3.1计算机管理硬件 3.2 管理逻辑图 3.3 怎样管理 4 什么是进程? 5 查看进程 5.1 ps ajx显示所有进程信息 5.2 /proc(内存文件系统) 5.2.1 ls /proc/PID 5.2.2 ls /proc/PID -al 5…...
web3.0简介
Web3.0(或简称 Web3)是近年来广泛讨论的一个新型互联网概念,其核心思想在于利用区块链及相关分布式技术,打造一个更加开放、去中心化、透明且以用户为主导的网络生态系统。这意味着在 Web3.0 时代,用户不再只是信息的消…...
前端控制器模式
前端控制器模式 引言 在软件设计模式中,前端控制器模式(Front Controller Pattern)是一种行为型设计模式。它提供了一种集中处理请求的机制,将请求分发到相应的处理者,从而简化了请求的处理流程。本文将详细介绍前端…...
【保姆级视频教程(二)】YOLOv12训练数据集构建:标签格式转换-划分-YAML 配置 避坑指南 | 小白也能轻松玩转目标检测!
【2025全站首发】YOLOv12训练数据集构建:标签格式转换-划分-YAML 配置 避坑指南 | 小白也能轻松玩转目标检测! 文章目录 1. 数据集准备1.1 标签格式转换1.2 数据集划分1.3 yaml配置文件创建 2. 训练验证 1. 数据集准备 示例数据集下载链接:P…...
SpringBoot接口自动化测试实战:从OpenAPI到压力测试全解析
引言:接口测试的必要性 在微服务架构盛行的今天,SpringBoot项目的接口质量直接影响着系统稳定性。本文将分享如何通过自动化工具链实现接口的功能验证与性能压测,使用OpenAPI规范打通测试全流程,让您的接口质量保障体系更加完备。…...
Spring学习笔记02——bean的概念和常见注解标注
什么是bean? Bean 就是 被 Spring 管理的对象,就像工厂流水线上生产的“标准产品”。这些对象不是你自己 new 出来的,而是由 Spring 容器(一个超级工厂)帮你创建、组装、管理。 由 Component、Service、Controller 等注解标记的…...
JAVA最新版本详细安装教程(附安装包)
目录 文章自述 一、JAVA下载 二、JAVA安装 1.首先在D盘创建【java/jdk-23】文件夹 2.把下载的压缩包移动到【jdk-23】文件夹内,右键点击【解压到当前文件夹】 3.如图解压会有【jdk-23.0.1】文件 4.右键桌面此电脑,点击【属性】 5.下滑滚动条&…...
Redis学习笔记系列(一)——Redis简介及安装
1. Redis介绍 Redis是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。 Redis与其他key-value缓存产品有以下三个特点: Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行…...
【0005】Python变量详解
如果你觉得我的文章写的不错,请关注我哟,请点赞、评论,收藏此文章,谢谢! 本文内容体系结构如下: 任何一个语言编写的程序或者项目,都需要数据的支持,没有数据的项目不能称之为一个…...
实验:k8s+keepalived+nginx+iptables
1、创建两个nginx的pod,app都是nginx nginx1 nginx2 2、创建两个的pod的service 3、配置两台keepalived的调度器和nginx七层反向代理,VIP设置192.168.254.110 keepalived调度器master keepalived调度器backup 两台调度器都配置nginx七层反向代理&#…...
经典算法 统计数字问题(常数时间解决)
统计数字问题 一本书的页码从自然数1 开始顺序编码直到自然数n。书的页码按照通常的习惯编排,每个页码都不含多余的前导数字0。例如,第6 页用数字6 表示,而不是06 或006 等。数字计数问题要求对给定书的总页码n,计算出书的全部页…...
ViewPager2跟ViewPager的区别
1都是用来实现页面切换的,ViewPager2是ViewPager的增强版和升级版,ViewPager2是基于RecyclerView实现,可以支持横向和竖向页面切换,只需在布局文件添加一个android:orientation"vertical"即可,ViewPager只支…...
Github 仓库 git clone 速度过慢解决方案
很多时候想从 GitHub 上 clone 一个仓库,都会遇到速度慢的问题,而且经常连接失败,这里给出有效解决方案。 一、背景 应该是很多小伙伴碰到过的问题:想从 GitHub 上面 clone 项目,很多情况下会慢的离谱,等…...
数据结构 1-3 栈
一、原理 栈是只允许在一端进行插入或删除操作的线性表 所谓的栈,其实就是一个特殊的线性表(顺序表、链表),但是它在操作上有一些特殊的要求和限制: 栈的元素必须“后进先出”栈的操作只能在这个线性表的表尾进行。…...
MCP与RAG:增强大型语言模型的两种路径
引言 近年来,大型语言模型(LLM)在自然语言处理任务中展现了令人印象深刻的能力。然而,这些模型的局限性,如知识过时、生成幻觉(hallucination)等问题,促使研究人员开发了多种增强技…...
【Git】Ubuntu 安装 Git Large File Storage(LFS)以及使用 Git LFS 下载
【Git】Ubuntu 安装 Git Large File Storage(LFS)以及使用 Git LFS 下载 1 安装1.1 使用脚本安装1.2 使用 packagecloud 安装 2 使用2.1 下载 1 安装 1.1 使用脚本安装 参考文档: Link 下载安装包: Link 解压安装包 tar -xzvf git-lfs-linux-amd64-v3.…...
int new_pos = (pos + delta + 9) % 9 化曲为直算法
公式 int new_pos (pos delta 9) % 9; 是一个常见的 循环数组索引计算 方法,用于处理圆圈排列中的位置计算。这个公式可以总结出一个普遍的规律,适用于任何循环数组或圆圈排列的场景。 普遍规律 假设有一个长度为 ( n ) 的循环数组(或圆圈…...
在已有的原生 App 里嵌入 Flutter 页面的方法
在原生 App 中嵌入 Flutter 页面,通常使用 Flutter 提供的**平台通道(Platform Channels)**来实现原生代码与 Flutter 之间的交互。具体实现方式依赖于原生 App 的平台(如 Android 或 iOS),下面是两种常见的…...
hive 面试题
Hive基础概念 1.1 Hive是什么? 基于Hadoop的数据仓库工具,支持类SQL(HiveQL)查询,底层转换为MapReduce/Tez/Spark任务。 核心功能:数据ETL、查询、分析;定位:OLAP(分析…...
不同数据类型在数据库和编程语言之间的对应关系表
不同数据类型在数据库和编程语言之间的对应关系表 MySql 与 C# MySqlC#varcharstringbigintlongbigint unsignedulongintintint unsigneduintsmallintshortsmallint unsignedushortVARCHAR(36)GuidsmalldatetimeDateTimedateDateTimedatetimeDateTimetimestampDateTimefloatf…...
【笔记】用大预言模型构建专家系统
最近闲庭漫步,赏一赏各个AI大语言模型芳容。也趁着时间,把倪海夏一家的天纪和人纪视频看完了,感谢倪先生和现在网络的知识分享,受益匪浅。但是发现看完,很多不错的知识都不能记录在脑子里,那用的时候岂不是…...
P2P 下载科普:原理与应用
P2P 下载科普:原理与应用 1. 什么是 P2P 下载? P2P(Peer-to-Peer,点对点)下载是一种去中心化的文件传输方式,不依赖单一服务器,而是通过多个用户(节点,peers࿰…...
IO和NIO
IO和NIO在定义、面向对象、模式、选择器等方面存在显著的差异。以下是对IO和NIO的详细对比: 一、定义 IO(Input/Output): IO是计算机中的输入/输出(Input/Output)的简称,指的是计算机系统与外…...
从零开始:H20服务器上DeepSeek R1 671B大模型部署与压力测试全攻略
前言 最近,我有幸在工作中接触到了DeepSeek R1 671B模型,这是目前中文开源领域参数量最大的高质量模型之一。DeepSeek团队在2024年推出的这款模型,以其惊人的6710亿参数量和出色的推理性能,引起了业界广泛关注。 作为一名AI基础…...
设计模式--spring中用到的设计模式
一、单例模式(Singleton Pattern) 定义:确保一个类只有一个实例,并提供全局访问点 Spring中的应用:Spring默认将Bean配置为单例模式 案例: Component public class MySingletonBean {// Spring 默认将其…...
散户如何实现自动化交易下单——篇1:体系介绍与获取同花顺资金账户和持仓信息
一、为什么要实现自动化交易 在瞬息万变的金融市场中,越来越多的散户投资者开始尝试构建自己的交易策略:有人通过技术指标捕捉趋势突破,有人利用基本面分析挖掘低估标的,还有人设计出复杂的网格交易或均值回归模型。然而&a…...
SpringBoot高校运动会管理系统 附带详细运行指导视频
文章目录 一、项目演示二、项目介绍三、运行截图四、主要代码1.报名赛事代码2.用户登录代码3.保存成绩代码 一、项目演示 项目演示地址: 视频地址 二、项目介绍 项目描述:这是一个基于SpringBoot框架开发的高校运动会管理系统项目。首先,这…...
MySQL表字段数量上限解析
MySQL 表中最多可以创建的字段数量取决于以下几个因素,主要包括 存储引擎 和 行大小限制: 1. 理论上的字段数量上限 InnoDB 存储引擎(MySQL 5.6): 最多 1017 个字段(实际测试中可能略低,需考虑行大小限制&…...
2024 ChatGPT大模型技术场景与商业应用视频精讲合集(45课).zip
2024ChatGPT大模型技术场景与商业应用视频精讲合集,共十三章,45课。 01. 第一章 ChatGPT:通用人工智能的典范 1.1 ChatGPT概述 .mp4 1.2 通用能力 .mp4 1.3 通用人工智能风口 .mp4 02. 第二章 大模型:ChatGPT的核心支撑 2.1 底层…...
FastExcel vs EasyExcel vs Apache POI:三者的全面对比分析
一、核心定位与历史沿革 Apache POI(1990s-) 作为Java生态中最古老的Excel处理库,提供对.xls/.xlsx文件的全功能支持。其核心价值在于对Excel规范的完整实现,包括单元格样式、公式计算、图表操作等深度功能。但存在内存消耗大&…...
线程控制(创建、终止、等待、分离)
目录 1.前言 2.创建线程 pthread_create函数 3.线程终止 pthread_exit函数 pthread_cancel函数 4.线程等待 5.线程分离 1.前言 在Linux系统中,并不存在真正的线程,只有轻量级进程。所以,Linux系统只提供了操作轻量级进程的系统调用…...
秒杀系统的常用架构是什么?怎么设计?
架构 秒杀系统需要单独部署,如果说放在订单服务里面,秒杀的系统压力太大了就会影响正常的用户下单。 常用架构: Redis 数据倾斜问题 第一步扣减库存时 假设现在有 10 个商品需要秒杀,正常情况下,这 10 个商品应该均…...
2025年生成式人工智能应用工程师学习线路
生成式人工智能应用工程师学习线路 初级 掌握AIGC基础概念、法律规范及安全基础、提示词使用及优化技巧,具备使用文心一言、Stable Diffsion、Midjourney等常见大模型应用进行高质量的文案、图片、视频创作的能力 课程内容包括:AIGC基础、职业道德、数…...
python力扣3:无重复字符的最长子串
给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。 示例 1: 输入: s “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 示例 2: 输入: s “bbbbb” 输出: 1 解释: 因为无重复字符的最长子串是 “b”…...
文生图开源模型发展史(2014-2025年)
文生图开源模型的发展历程是一段充满技术革新、社区生态繁荣与商业化竞争的多维度演进史。 一、技术萌芽期(2014-2020年) 核心突破 2014年:GAN(生成对抗网络)诞生,首次实现数据驱动式图像生成࿰…...
fastadmin 后台商品sku(vue)
先上个效果图 首先先引入vue define([backend], function (Backend) {require.config({paths: {vue: /assets/jeekshopskugoods/libs/vue.min,skuimg: /assets/jeekshopskugoods/js/skuimg,skugoods: /assets/jeekshopskugoods/js/skugoods,layui: /assets/LayuiSpzj/layui/la…...
Qt显示一个hello world
一、显示思路 思路一:通过图形化方式,界面上创建出一个控件显示。 思路二:通过编写C代码在界面上创建控件显示。 二、思路一实现 点开 Froms 的 widget.ui,拖拽 label 控件,显示 hello world 即可。 qmake 基于 .…...
LeetCode 热题 100 53. 最大子数组和
LeetCode 热题 100 | 53. 最大子数组和 大家好,今天我们来解决一道经典的算法题——最大子数组和。这道题在 LeetCode 上被标记为中等难度,要求我们找出一个具有最大和的连续子数组,并返回其最大和。下面我将详细讲解解题思路,并…...
需求: 使用 minio 做一个 企业微信对话的下载、存储,利用deepseek进行对话回复
以下是基于企业微信会话存档API和MinIO对象存储实现对话记录下载与存储的完整方案,涵盖技术选型、接口对接、存储配置及安全性设计等核心环节: 一、技术架构设计 系统组成: 数据采集层:通过企业微信API拉取会话存档数据࿰…...
vulnhub靶场之【digitalworld.local系列】的bravery靶机
前言 靶机:digitalworld.local-bravery,IP地址为192.168.10.8 攻击:kali,IP地址为192.168.10.6 kali采用VMware虚拟机,靶机采用virtualbox虚拟机,网卡都为桥接模式 这里官方给的有两种方式,…...
JMeter 实战项目脚本录制最佳实践(含 BadBoy 录制方式)
JMeter 实战项目脚本录制最佳实践(含 BadBoy 录制方式) 一、项目背景 在软件测试过程中,使用 JMeter 进行性能测试和功能测试是常见的操作。本实战项目将详细介绍如何使用 JMeter 自带工具以及 BadBoy 进行脚本录制,并完善脚本以…...
数据库基础五(数据库环境变量配置详细教程)
1、在小皮的设置界面检测3306端口,保障3306端口可用; 2、在小皮的首面界面,启动MySQL; 3、进行环境变量设置,找到MySQL的路径,进行复制; 4、在Windows的搜索栏内,输入“环境变量”&a…...
Matlab 大量接单
分享一个matlab接私活、兼职的平台 1、技术方向满足任一即可 2、技术要求 3、最后 技术方向满足即可 MATLAB:熟练掌握MATLAB编程语言,能够使用MATLAB进行数据处理、机器学习和深度学习等相关工作。 机器学习、深度学习、强化学习、仿真、复现、算法、…...
【算法】链表题型总结
链表题型可分为快慢指针和虚拟头节点两种解题技巧。 快慢指针 使用两个指针(快指针和慢指针),以不同的速度遍历链表,解决与链表位置、环检测相关的问题。 反转链表 快慢指针,慢指针一次走一步,快指针一次…...
【C++】对字符串的常用操作
C 中的字符串操作主要通过两种方式实现:使用 C 风格的字符串(字符数组)和使用 C 标准库中的 std::string 类型。大多数现代 C 程序使用 std::string 进行字符串处理,因为它提供了许多便捷的成员函数来处理字符串操作。以下是常见的…...