C#验证Email是否真正存在

2024-04-25 10:58

本文主要是介绍C#验证Email是否真正存在,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在以往的编程中,比如编写用户的资料时,有时需要确认用户输入的Email是否真实有效,以前我们最多只能做到验证Email是否包含了某些特殊的字符,比如 "@ ", ". ", ".com "等,做到的只是判断了Email的合法性,证明用户填写的Email格式是正确的,但是这个Email是否真正的存在于网络中,则没有办法。  
 首先需要大家了解一下SMTP协议。  
1.SMTP是工作在两种情况下:一是电子邮件从客户机传输到服务器;二是从某一个服务器传输到另一个  
  服务器  
2.SMTP是个请求/响应协议,命令和响应都是基于ASCII文本,并以CR和LF符结束。响应包括一个表示返   
  回状态的三位数字代码  
3.SMTP在TCP协议25号端口监听连接请求  
4.连接和发送过程  
SMTP协议说复杂也不复杂(明明带有“简单”这个词嘛),说简单如果你懂得Sock。不过现在只是我们利用的就是第一条中说的,从客户机传输到服务器,当我们向一台服务器发送邮件时,邮件服务器会首先验证邮件发送地址是否真的存在于本服务器上。  
操作的步骤如下:  
连接服务器的25端口(如果没有邮件服务,连了也是白连)  
发送helo问候  
发送mail   from命令,如果返回250表示正确可以,连接本服务器,否则则表示服务器需要发送人验证。  
发送rcpt   to命令,如果返回250表示则Email存在  
发送quit命令,退出连接  
下面我们就来操作这个流程:  
首先看看页面构架:  
<b> 普通的Email验证 </b>  
<form   runat= "server ">  
<table   boder= "#6699FF ">  
<tr> <td   colspan= "2 "   align= "center "   > <asp:Label   id= "lblMsgShow "   ForeColor= "red "   runat= "server "   /> </td> </tr>  
<tr> <td> 需要验证的Email地址: </td> <td> <asp:TextBox   id= "tbEmail "   runat= "server "   /> </td> </tr>  
<tr> <td> 邮件SMTP服务器: </td> <td> <asp:TextBox   id= "tbServer "   runat= "server "   /> </td> </tr>  
<tr> <td> SMTP端口: </td> <td> <asp:TextBox   id= "tbPort "   Text= "25 "   runat= "server "   /> </td> </tr>  
<tr> <td   colspan= "2 "   > <asp:Button   id= "btnValidate "   Text= "验证 "   OnClick= "Validate_Email "   runat= "server "   /> </td> </tr>  
</table>  
<b> 验证过程展示: </b>  
<asp:Panel   id= "ShowPro "   runat= "server "   />  
</form>  
Button控件的点击将激发Valiate_Email事件,所有主程序操作全是在这个事件中完成,下面就来具体讲解本事件处理中的代码。  
关于TCP连接的东东,我就不想再重复了。。请大家自己去看我以前的文章:  
string   strEmail,strServer;  
int   intPort;  
strEmail   =   tbEmail.Text;  
strServer   =   tbServer.Text;  
intPort   =   Int32.Parse(tbPort.Text);   file://默认端口是25  

TcpClient   tcpc   =   new   TcpClient();  
服务器等信息来自于用户输入,建立与服务器25端口的连接。  

try  
{  
tcpc.Connect(strServer,intPort);  
StreamReader   sr   =   new   StreamReader(tcpc.GetStream(),Encoding.Default);  
sr.ReadLine();  
...  
}  
请注意上面代码中两点:一在beta2中不能再通过判断返回值的方法来判断建立的连接是否成功,只能通过捕捉错误例外的方法判断;二在打开连接,使用Stream读取时,必须有一个sr.ReadLine,一行是服务器的欢迎信息加版本信息。  

接下来就是按照上面所说的步骤来完成操作:  

file://写入HELO命令  
if(OperaStream(tcpc, "HELOhttp://www.webjx.com ")   !=   "250 ")  
{  
lblMsgShow.Text   =   "HELO   命令不能完成,本端口可能并非提供SMTP服务 ";  
OperaStream(tcpc, "QUIT ");  
return;  
}  
file://写入Mail   From命令  
if(OperaStream(tcpc, "MAIL   FROM:   web@webjx.com ")   !=   "250 ")  
{  
lblMsgShow.Text   =   "MAIL命令不能完成,SMTP服务需要验证 ";  
OperaStream(tcpc, "QUIT ");  
return;  
}  
file://写入RCPT命令,这是关键的一步,后面的参数便是查询的Email的地址  
if(OperaStream(tcpc, "RCPT   TO:   "+strEmail)   !=   "250 ")  
{  
lblMsgShow.Text   =   strEmail   +   "此邮件地址并非有效 ";  
OperaStream(tcpc, "QUIT ");  
return;  
}  
else  
{  
lblMsgShow.Text   =   strEmail   +   "是一个合法有效的邮件地址 ";  
OperaStream(tcpc, "QUIT ");  
return;  
}  
Helo命令后面的主机名,在某些邮件服务器中不需要比如Imail,但是还是写上好,当然你也可以乱写骗服务器,不过一般来说服务器都能检查出来。  

其中OperaStrem是我们是自定义的函数,用于操作连接流:  

public   string   OperaStream(TcpClient   tcpc,string   strCmd)  
{  
Stream   TcpStream;  
strCmd   =   strCmd   +   "/r/n ";   file://加入换行符  
TcpStream   =   tcpc.GetStream();  
byte[]   bWrite   =   Encoding.Default.GetBytes(strCmd.ToCharArray());  
TcpStream.Write(bWrite,0,bWrite.Length);  
StreamReader   sr   =   new   StreamReader(tcpc.GetStream(),Encoding.Default);  
string   rl   =   sr.ReadLine();  
string   sp   =   rl.Substring(0,3);  
ShowPro.Controls.Add(new   LiteralControl( "执行命令: <font   color=red> "+strCmd+ " </font> <br> 返回数据: "+rl+ " <br> "));  
return   sp;  
}  
此函数的返回值是流的信息代码,用于判断操作是否成功,250表示成功,550表示只能适用于本地邮件,也就是说发件人必须是该服务器上的用户,比如在连接smtp.163.net,就必须拥有一个真实有效的163.net帐号,这种做法是服务器防止外人使用服务发送垃圾邮件

转http://bbs.csai.cn/bbs/view.asp?Id={67F53C96-8D2E-450E-BD69-67A68A8CE90E} 

这篇关于C#验证Email是否真正存在的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934487

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

Codeforces Round #113 (Div. 2) B 判断多边形是否在凸包内

题目点击打开链接 凸多边形A, 多边形B, 判断B是否严格在A内。  注意AB有重点 。  将A,B上的点合在一起求凸包,如果凸包上的点是B的某个点,则B肯定不在A内。 或者说B上的某点在凸包的边上则也说明B不严格在A里面。 这个处理有个巧妙的方法,只需在求凸包的时候, <=  改成< 也就是说凸包一条边上的所有点都重复点都记录在凸包里面了。 另外不能去重点。 int

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal

easyui 验证下拉菜单select

validatebox.js中添加以下方法: selectRequired: {validator: function (value) {if (value == "" || value.indexOf('请选择') >= 0 || value.indexOf('全部') >= 0) {return false;}else {return true;}},message: '该下拉框为必选项'}

【408DS算法题】039进阶-判断图中路径是否存在

Index 题目分析实现总结 题目 对于给定的图G,设计函数实现判断G中是否含有从start结点到stop结点的路径。 分析实现 对于图的路径的存在性判断,有两种做法:(本文的实现均基于邻接矩阵存储方式的图) 1.图的BFS BFS的思路相对比较直观——从起始结点出发进行层次遍历,遍历过程中遇到结点i就表示存在路径start->i,故只需判断每个结点i是否就是stop