天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

C# 郵件地址是否合法的驗證

復制代碼 代碼如下:
/// <summary>
/// 檢測輸入的郵件地址strEmail是否合法,非法則返回true。
/// </summary>
public bool CheckEmail(string strEmail)
{
int i, j;
string strTmp, strResult;
string strWords = "abcdefghijklmnopqrstuvwxyz_-.0123456789"; //定義合法字符范圍
bool blResult = false;
strTmp = strEmail.Trim();
//檢測輸入字符串是否為空,不為空時才執行代碼。
if (!(strTmp == "" || strTmp.Length == 0))
{
//判斷郵件地址中是否存在“@”號
if ((strTmp.IndexOf("@") < 0))
{
blResult = true;
return blResult;
}
//以“@”號為分割符,把地址切分成兩部分,分別進行驗證。
string[] strChars = strTmp.Split(new char[] { '@' });
foreach (string strChar in strChars)
{
i = strChar.Length;
//“@”號前部分或后部分為空時。
if (i == 0)
{
blResult = true;
return blResult;
}
//逐個字進行驗證,如果超出所定義的字符范圍strWords,則表示地址非法。
for (j = 0; j < i; j++)
{
strResult = strChar.Substring(j, 1).ToLower();//逐個字符取出比較
if (strWords.IndexOf(strResult) < 0)
{
blResult = true;
return blResult;
}
}
}
}
return blResult;
}

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: [email protected]") != "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帳號,這種做法是服務器防止外人使用服務發送垃圾郵件

AspNet技術C# 郵件地址是否合法的驗證,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲伊人精品综合在合线 | 亚洲国产精品一区二区三区在线观看 | 亚洲中文字幕国产综合 | 久久精品国产亚洲AV天美18 | 亚洲欧美韩国综合色 | 久久人妻熟女中文字幕AV蜜芽 | 国产精品麻豆高潮刺激A片 国产精品麻豆a在线播放 | 日本xxx在线观看免费播放 | 中文字幕高清在线观看 | 沟沟人体一区二区 | 久久综合色悠悠 | 亚洲精品久久久无码一区二区 | 国内精品视频一区二区在线观看 | 美国色情三级欧美三级纸匠情挑 | 少妇连续高潮抽搐痉挛昏厥 | 欧美精品九九99久久在免费线 | 亚洲合集综合久久性色 | 亚洲午夜精品AV无码少妇 | 亚洲伊人久久一次 | 月夜直播免费看 | 国产精品伦一区二区三级视频 | 亚洲精品在看在线观看 | 99视频在线免费观看 | 久久亚洲国产成人影院 | 久久99re2热在线播放7 | 西施打开双腿下面好紧 | 伊人yinren6综合网色狠狠 | 成人小视频在线观看 | 亚洲黄色在线 | 欧美老妇与zozoz0交 | 蜜柚影院在线观看免费高清中文 | 亚洲成人三级 | 一本道无码字幕在线看 | 国产亚洲精品久久久闺蜜 | 蜜桃狠狠色伊人亚洲综合网站 | 日本漫画大全无翼乌 | 美女乱草鲍高清照片 | 高清一区二区亚洲欧美日韩 | 国产精品人成在线播放新网站 | 久久久中日AB精品综合 | 午夜精品久久久久久影视riav |