本文目錄一覽:
- 1、win2003服務器上安裝Advanced SMTP Server使用php程序發送郵件全部都提示被當做垃圾郵件屏蔽掉,怎麼回事
- 2、php發送郵件到hotmail、QQ郵箱等變垃圾郵件的解決辦法
- 3、php提交表單到郵箱多次後,出現垃圾郵件被退回的現象要怎麼解決
- 4、如何正確運用PHP發送郵件函數
- 5、php發送的郵件都被默認為垃圾郵件,該怎麼解決
win2003服務器上安裝Advanced SMTP Server使用php程序發送郵件全部都提示被當做垃圾郵件屏蔽掉,怎麼回事
把smtp服務器設置成使用默認的就好了,然後服務器端將smtp設置清空,不保存和使用賬號密碼就好了、
php發送郵件到hotmail、QQ郵箱等變垃圾郵件的解決辦法
使用socket 連接專業的郵件服務器(如QQ、 163等)完成發送郵件,這樣就不會被認為是垃圾郵件了
fsockopen(“smtp.qq.com”, 25)
php提交表單到郵箱多次後,出現垃圾郵件被退回的現象要怎麼解決
這個是無法解決的,一個郵箱如果收到過非常多次同一個人發的郵件,那麼這個人將會被標記成垃圾郵件。這本身是郵件系統的防禦功能。當然如163,qq等有更先進的防護措施,包括自動識別,雲數據庫
如何正確運用PHP發送郵件函數
PHP發送郵件函數的應用代碼示例:
#echo send_mail($_POST[“email”],$tosubject,$_POST[“errortext”]);
echo send_mail(‘someone@126.com’,’only a test mail for test php mail function’,’一封垃圾郵件’);
echo time();
function send_mail($to, $subject = ‘No subject’, $body) {
$loc_host = “mail.server”; //發信計算機名,可隨意
$smtp_acc = “smp@163.com”; //Smtp認證的用戶名
$smtp_pass=”pwdpwd”; //Smtp認證的密碼,一般等同pop3密碼
$smtp_host=”smtp.163.com”; //SMTP服務器地址,類似 smtp.tom.com
$from=”smp@163.com”; //發信人Email地址,你的發信信箱地址
$deliver=$smtp_acc; //回復到指定郵箱
$headers = “Content-Type: text/plain; charset=”gb2312″rnContent-Transfer-Encoding: base64”;
$lb=”rn”; //linebreak
$hdr = explode($lb,$headers); //解析後的hdr
if($body) {$bdy = preg_replace(“/^./”,”..”,explode($lb,$body));}//解析後的Body
$smtp = array(
//1、EHLO,期待返回220或者250
array(“EHLO “.$loc_host.$lb,”220,250”,”HELO error: “),
//2、發送Auth Login,期待返回334
array(“AUTH LOGIN”.$lb,”334″,”AUTH error:”),
//3、發送經過Base64編碼的用戶名,期待返回334
array(base64_encode($smtp_acc).$lb,”334″,”AUTHENTIFICATION error : “),
//4、發送經過Base64編碼的密碼,期待返回235
array(base64_encode($smtp_pass).$lb,”235″,”AUTHENTIFICATION error : “));
//5、發送Mail From,期待返回250
$smtp[] = array(“MAIL FROM: “.$from.””.$lb,”250″,”MAIL FROM error: “);
//6、發送Rcpt To。期待返回250
$smtp[] = array(“RCPT TO: “.$to.””.$lb,”250″,”RCPT TO error: “);
//7、發送DATA,期待返回354
$smtp[] = array(“DATA”.$lb,”354″,”DATA error: “);
//8.0、發送From
$smtp[] = array(“From: “.$deliver.$lb,””,””);
//8.2、發送To
$smtp[] = array(“To: “.$to.$lb,””,””);
//8.1、發送標題
$smtp[] = array(“Subject: “.$subject.$lb,””,””);
//8.3、發送其他Header內容
foreach($hdr as $h) {$smtp[] = array($h.$lb,””,””);}
//8.4、發送一個空行,結束Header發送
$smtp[] = array($lb,””,””);
//8.5、發送信件主體
if($bdy) {foreach($bdy as $b) {$smtp[] = array(base64_encode($b.$lb).$lb,””,””);}}
//9、發送「.」表示信件結束,期待返回250
$smtp[] = array(“.”.$lb,”250″,”DATA(end)error: “);
//10、發送Quit,退出,期待返回221
$smtp[] = array(“QUIT”.$lb,”221″,”QUIT error: “);
//打開smtp服務器端口
$fp = @fsockopen($smtp_host, 25);
if (!$fp) echo “bError:/b Cannot conect to “.$smtp_host.”br”;
while($result = @fgets($fp, 1024)){if(substr($result,3,1) == ” “) { break; }}
$result_str=””;
//發送smtp數組中的命令/數據
foreach($smtp as $req){
//發送信息
@fputs($fp, $req[0]);
//如果需要接收服務器返回信息,則
if($req[1]){
//接收信息
while($result = @fgets($fp, 1024)){
if(substr($result,3,1) == ” “) { break; }
};
if (!strstr($req[1],substr($result,0,3))){
$result_str.=$req[2].$result.”br”;
}
}
}
//關閉連接
@fclose($fp);
return $result_str;
}
希望上面這段代碼示例能讓大家充分掌握PHP發送郵件函數的運用。
php發送的郵件都被默認為垃圾郵件,該怎麼解決
現在的垃圾郵件的攔截機制主要靠的是你發送郵件的IP的信用度,如果沒有維護過的話默認情況下你的信用度是極低的,所有信件都會默認辨識為垃圾郵件。
比較好的方法是使用一些信用度高的郵件服務器來發送郵件。比方說Mailchimp
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/156637.html