復制代碼 代碼如下:
/// <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帳號,這種做法是服務器防止外人使用服務發送垃圾郵件