本文實例講述了php通過smtp郵件驗證登陸的方法。分享給大家供大家參考,具體如下:
內網的系統為了統一賬號,都采用用郵件賬號登陸的方式,所以有了以下程序
/*** 通過郵件 驗證登陸* 這里要明白的是用戶名是 帶域名的:aaa@163.com*/function valideEmailLogin($user, $pass, $smtp_server= 'smtp.163.com', $port=25){$handle = fsockopen($smtp_server, $port);if(!$handle)return false;$mes = fgets($handle);//echo $mes;if(!$mes){fclose($handle);return false;}$status = explode(" ",$mes);if($status[0] != 220) { //鏈接服務器失敗fclose($handle);return false;}fwrite($handle, 'HELO mystore'."/r/n"); //表明身份,這里的mystore是隨便寫的$mes = fgets($handle);//echo $mes;if(!$mes){fclose($handle);return false;}$status = explode(" ",$mes);if($status[0] != 250) { //服務器HELO失敗fclose($handle);return false;}fwrite($handle, 'AUTH LOGIN'."/r/n");$mes = fgets($handle);//echo $mes;if(!$mes){fclose($handle);return false;}$status = explode(" ",$mes);if($status[0] != 334) { //請求驗證登陸失敗fclose($handle);return false;}fwrite($handle,base64_encode($user)."/r/n");$mes = fgets($handle);//echo $mes;if(!$mes){fclose($handle);return false;}$status = explode(" ",$mes);if($status[0] != 334) { //驗證用戶名失敗fclose($handle);return false;}fputs($handle,base64_encode($pass)."/r/n"); $mes = fgets($handle);//echo $mes;if(!$mes){fclose($handle);return false;}$status = explode(" ",$mes);fclose($handle);if($status[0] != 235) { //驗證密碼失敗return false;}else{return true;}}