目錄
设置方法
图片演示
表单
PHP发邮件-BY TANKING
提交表单
发送邮件处理
尝试发邮件试试!
成功!不会进入垃圾箱!
首頁 後端開發 php教程 PHP簡單實作發送郵件和防被當成垃圾郵件處理

PHP簡單實作發送郵件和防被當成垃圾郵件處理

Jul 09, 2018 am 10:17 AM
email php phpmailer 郵件系統 信箱

这篇文章主要介绍了关于PHP简单实现发送邮件和防被当成垃圾邮件处理,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

邮件服务器使用的是163邮箱的
需要去163邮箱申请邮箱和设置客户端授权密码。

设置方法

登录163邮箱->设置->POP3/SMTP/IMAP->客户端授权密码

图片演示

PHP簡單實作發送郵件和防被當成垃圾郵件處理

PHP簡單實作發送郵件和防被當成垃圾郵件處理

设置好要记住!

下面就是代码了

表单

index.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
    <title>PHP发邮件 - BY TANKING</title>
        <style type="text/css">
    *{margin:0px;padding: 0px;}
            h3{
                    text-align: center;
                    margin-top: 50px;
            }
 
                #form-p{
                        width: 300px;
                        margin:20px auto;
                }
 
                #form-p .input_style{
                        width: 100%;
                        height: 35px;
                        font-size: 16px;
                        text-indent: 5px;
                        margin-bottom: 5px;
                }
 
                #form-p .textarea_style{
                        width: 100%;
                        height: 65px;
                        font-size: 16px;
                        text-indent: 5px;
                        resize: none;
                }
 
                #form-p .sendbtn{
                        width: 100%;
                        height: 35px;
                        font-size: 16px;
                        cursor: pointer;
                        margin-top: 5px;
                }
 
                #result .yes{
                        position: fixed;
                        top: 0px;
                        background: #5cb85c;
                        width: 100%;
                        height: 35px;
                        line-height: 35px;
                        text-align: center;
                        color: #fff;
                        font-weight: bold;
                }
 
                #result .no{
                        position: fixed;
                        top: 0px;
                        background: #c00;
                        width: 100%;
                        height: 35px;
                        line-height: 35px;
                        text-align: center;
                        color: #fff;
                        font-weight: bold;
                }
 
    </style>
</head>
<body>
<h3 id="PHP发邮件-BY-nbsp-TANKING">PHP发邮件-BY TANKING</h3>
<p id="form-p">
    <form action="mail.php" method="POST">
       <input name="email" type="text" placeholder="接收邮箱" class="input_style"/><br/>
       <input name="title" type="text" placeholder="标题" class="input_style"/><br/>
       <input name="content" type="text" placeholder="内容" class="input_style"/><br/>
       <input type="submit" value="发送" class="sendbtn"/>
    </form>
</p>
</body>
</html>
登入後複製

提交表单

PHP簡單實作發送郵件和防被當成垃圾郵件處理

发送邮件处理

mail.php

<?php
//获取表单提交的邮件标题
$title = $_POST["title"];
//获取表单提交的内容
$content = $_POST["content"];
include_once("smtp.class.php");
    $smtpserver = "smtp.163.com"; //SMTP服务器
    $smtpserverport = 25; //SMTP服务器端口
    //获取表单提交的邮件接收人邮箱号码
    $email = $_POST["email"];
    $smtpusermail = "你的163邮箱地址"; //SMTP服务器的用户邮箱
    $smtpuser = "你的163邮箱地址"; //SMTP服务器的用户帐号
    $smtppass = "授权密码"; //SMTP服务器的授权密码
    $smtp = new Smtp($smtpserver, $smtpserverport, true, $smtpuser, $smtppass); //这里面的一个true是表示使用身份验证,否则不使用身份验证.
    $emailtype = "HTML"; //信件类型,文本:text;网页:HTML
    $smtpemailto = $email;
    $smtpemailfrom = $smtpusermail;
    $emailsubject = $title;
    $emailbody = "<p>".$content."</p>";
 
    //开始发送邮件
    $smtp->sendmail($smtpemailto, $smtpemailfrom, $emailsubject, $emailbody, $emailtype);
    echo "发送成功!";
?>
登入後複製

mail.php

里面只需设置你的163账号和授权密码即可

还有一个文件
smtp.class.php
这个不要动就行,拷贝到同一目录。

<?php
 
//TANKING
//2018-7-7
 
error_reporting(0);
class Smtp {
    /* Public Variables */
    var $smtp_port;
    var $time_out;
    var $host_name;
    var $log_file;
    var $relay_host;
    var $debug;
    var $auth;
    var $user;
    var $pass;
    /* Private Variables */
    var $sock;
    /* Constractor */
    function smtp($relay_host = "", $smtp_port = 25, $auth = false, $user, $pass) {
        $this->debug = false;
        $this->smtp_port = $smtp_port;
        $this->relay_host = $relay_host;
        $this->time_out = 30; //is used in fsockopen()
        $this->auth = $auth; //auth
        $this->user = $user;
        $this->pass = $pass;
        $this->host_name = "localhost"; //is used in HELO command
        $this->log_file = "";
        $this->sock = false;
    }
    /* Main Function */
    function sendmail($to, $from, $subject = "", $body = "", $mailtype, $cc = "", $bcc = "", $additional_headers = "") {
        $mail_from = $this->get_address($this->strip_comment($from));
        $body = ereg_replace("(^|(\r\n))(\.)", "\1.\3", $body);
        $header.= "MIME-Version:1.0\r\n";
        if ($mailtype == "HTML") {
            $header.= "Content-Type:text/html\r\n";
        }
        $header.= "To: " . $to . "\r\n";
        if ($cc != "") {
            $header.= "Cc: " . $cc . "\r\n";
        }
        $header.= "From: $from<" . $from . ">\r\n";
        $header.= "Subject: " . $subject . "\r\n";
        $header.= $additional_headers;
        $header.= "Date: " . date("r") . "\r\n";
        $header.= "X-Mailer:By Redhat (PHP/" . phpversion() . ")\r\n";
        list($msec, $sec) = explode(" ", microtime());
        $header.= "Message-ID: <" . date("YmdHis", $sec) . "." . ($msec * 1000000) . "." . $mail_from . ">\r\n";
        $TO = explode(",", $this->strip_comment($to));
        if ($cc != "") {
            $TO = array_merge($TO, explode(",", $this->strip_comment($cc)));
        }
        if ($bcc != "") {
            $TO = array_merge($TO, explode(",", $this->strip_comment($bcc)));
        }
        $sent = true;
        foreach ($TO as $rcpt_to) {
            $rcpt_to = $this->get_address($rcpt_to);
            if (!$this->smtp_sockopen($rcpt_to)) {
                $this->log_write("Error: Cannot send email to " . $rcpt_to . "\n");
                $sent = false;
                continue;
            }
            if ($this->smtp_send($this->host_name, $mail_from, $rcpt_to, $header, $body)) {
                $this->log_write("E-mail has been sent to <" . $rcpt_to . ">\n");
            } else {
                $this->log_write("Error: Cannot send email to <" . $rcpt_to . ">\n");
                $sent = false;
            }
            fclose($this->sock);
            $this->log_write("Disconnected from remote host\n");
        }
        return $sent;
    }
    /* Private Functions */
    function smtp_send($helo, $from, $to, $header, $body = "") {
        if (!$this->smtp_putcmd("HELO", $helo)) {
            return $this->smtp_error("sending HELO command");
        }
        // auth
        if ($this->auth) {
            if (!$this->smtp_putcmd("AUTH LOGIN", base64_encode($this->user))) {
                return $this->smtp_error("sending HELO command");
            }
            if (!$this->smtp_putcmd("", base64_encode($this->pass))) {
                return $this->smtp_error("sending HELO command");
            }
        }
        if (!$this->smtp_putcmd("MAIL", "FROM:<" . $from . ">")) {
            return $this->smtp_error("sending MAIL FROM command");
        }
        if (!$this->smtp_putcmd("RCPT", "TO:<" . $to . ">")) {
            return $this->smtp_error("sending RCPT TO command");
        }
        if (!$this->smtp_putcmd("DATA")) {
            return $this->smtp_error("sending DATA command");
        }
        if (!$this->smtp_message($header, $body)) {
            return $this->smtp_error("sending message");
        }
        if (!$this->smtp_eom()) {
            return $this->smtp_error("sending <CR><LF>.<CR><LF> [EOM]");
        }
        if (!$this->smtp_putcmd("QUIT")) {
            return $this->smtp_error("sending QUIT command");
        }
        return true;
    }
    function smtp_sockopen($address) {
        if ($this->relay_host == "") {
            return $this->smtp_sockopen_mx($address);
        } else {
            return $this->smtp_sockopen_relay();
        }
    }
    function smtp_sockopen_relay() {
        $this->log_write("Trying to " . $this->relay_host . ":" . $this->smtp_port . "\n");
        $this->sock = @fsockopen($this->relay_host, $this->smtp_port, $errno, $errstr, $this->time_out);
        if (!($this->sock && $this->smtp_ok())) {
            $this->log_write("Error: Cannot connenct to relay host " . $this->relay_host . "\n");
            $this->log_write("Error: " . $errstr . " (" . $errno . ")\n");
            return false;
        }
        $this->log_write("Connected to relay host " . $this->relay_host . "\n");
        return true;;
    }
    function smtp_sockopen_mx($address) {
        $domain = ereg_replace("^.+@([^@]+)$", "\1", $address);
        if (!@getmxrr($domain, $MXHOSTS)) {
            $this->log_write("Error: Cannot resolve MX \"" . $domain . "\"\n");
            return false;
        }
        foreach ($MXHOSTS as $host) {
            $this->log_write("Trying to " . $host . ":" . $this->smtp_port . "\n");
            $this->sock = @fsockopen($host, $this->smtp_port, $errno, $errstr, $this->time_out);
            if (!($this->sock && $this->smtp_ok())) {
                $this->log_write("Warning: Cannot connect to mx host " . $host . "\n");
                $this->log_write("Error: " . $errstr . " (" . $errno . ")\n");
                continue;
            }
            $this->log_write("Connected to mx host " . $host . "\n");
            return true;
        }
        $this->log_write("Error: Cannot connect to any mx hosts (" . implode(", ", $MXHOSTS) . ")\n");
        return false;
    }
    function smtp_message($header, $body) {
        fputs($this->sock, $header . "\r\n" . $body);
        $this->smtp_debug("> " . str_replace("\r\n", "\n" . "> ", $header . "\n> " . $body . "\n> "));
        return true;
    }
    function smtp_eom() {
        fputs($this->sock, "\r\n.\r\n");
        $this->smtp_debug(". [EOM]\n");
        return $this->smtp_ok();
    }
    function smtp_ok() {
        $response = str_replace("\r\n", "", fgets($this->sock, 512));
        $this->smtp_debug($response . "\n");
        if (!ereg("^[23]", $response)) {
            fputs($this->sock, "QUIT\r\n");
            fgets($this->sock, 512);
            $this->log_write("Error: Remote host returned \"" . $response . "\"\n");
            return false;
        }
        return true;
    }
    function smtp_putcmd($cmd, $arg = "") {
        if ($arg != "") {
            if ($cmd == "") $cmd = $arg;
            else $cmd = $cmd . " " . $arg;
        }
        fputs($this->sock, $cmd . "\r\n");
        $this->smtp_debug("> " . $cmd . "\n");
        return $this->smtp_ok();
    }
    function smtp_error($string) {
        $this->log_write("Error: Error occurred while " . $string . ".\n");
        return false;
    }
    function log_write($message) {
        $this->smtp_debug($message);
        if ($this->log_file == "") {
            return true;
        }
        $message = date("M d H:i:s ") . get_current_user() . "[" . getmypid() . "]: " . $message;
        if (!@file_exists($this->log_file) || !($fp = @fopen($this->log_file, "a"))) {
            $this->smtp_debug("Warning: Cannot open log file \"" . $this->log_file . "\"\n");
            return false;;
        }
        flock($fp, LOCK_EX);
        fputs($fp, $message);
        fclose($fp);
        return true;
    }
    function strip_comment($address) {
        $comment = "\([^()]*\)";
        while (ereg($comment, $address)) {
            $address = ereg_replace($comment, "", $address);
        }
        return $address;
    }
    function get_address($address) {
        $address = ereg_replace("([ \t\r\n])+", "", $address);
        $address = ereg_replace("^.*<(.+)>.*$", "\1", $address);
        return $address;
    }
    function smtp_debug($message) {
        if ($this->debug) {
            echo $message . "
 
                        ;";
        }
    }
}
?>
登入後複製

尝试发邮件试试!

PHP簡單實作發送郵件和防被當成垃圾郵件處理

PHP簡單實作發送郵件和防被當成垃圾郵件處理

成功!不会进入垃圾箱!

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

PHP获取客户端真实IP地址的方法

以上是PHP簡單實作發送郵件和防被當成垃圾郵件處理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

十大數字虛擬貨幣app排行榜 幣圈交易數字貨幣交易所排名前十 十大數字虛擬貨幣app排行榜 幣圈交易數字貨幣交易所排名前十 Apr 22, 2025 pm 03:00 PM

十大數字虛擬貨幣app排行榜分別是:1. OKX,2. Binance,3. gate.io,4. Coinbase,5. Kraken,6. Huobi,7. KuCoin,8. Bitfinex,9. Bitstamp,10. Poloniex。這些交易所根據交易量、用戶體驗和安全性等因素評選,均提供多種數字貨幣交易服務和高效的交易體驗。

IIS和PHP的兼容性:深度潛水 IIS和PHP的兼容性:深度潛水 Apr 22, 2025 am 12:01 AM

IIS和PHP可以兼容,通過FastCGI實現。 1.IIS通過配置文件將.php文件請求轉發給FastCGI模塊。 2.FastCGI模塊啟動PHP進程處理請求,提高性能和穩定性。 3.實際應用中需注意配置細節、錯誤調試和性能優化。

bitget新用戶註冊指南2025 bitget新用戶註冊指南2025 Apr 21, 2025 pm 10:09 PM

在2025年註冊Bitget的步驟包括:1.準備有效郵箱或手機號和穩定網絡;2.訪問Bitget官網;3.進入註冊頁面;4.選擇註冊方式;5.填寫註冊信息;6.同意用戶協議;7.完成驗證;8.獲取並填寫驗證碼;9.完成註冊。註冊後,建議登錄賬戶、進行KYC身份驗證,並設置安全措施以保障賬戶安全。

排名前十的數字貨幣交易所 數字貨幣app交易所排行榜前十 排名前十的數字貨幣交易所 數字貨幣app交易所排行榜前十 Apr 22, 2025 pm 03:15 PM

數字貨幣交易所排名前十分別是:1. OKX,2. Binance,3. gate.io,4. Coinbase,5. Kraken,6. Huobi,7. KuCoin,8. Bitfinex,9. Bitstamp,10. Poloniex。這些交易所根據交易量、用戶體驗和安全性等因素評選,均提供多種數字貨幣交易服務和高效的交易體驗。

兩個交易所之間可以互相轉幣嗎 交易所之間可以轉幣嗎 兩個交易所之間可以互相轉幣嗎 交易所之間可以轉幣嗎 Apr 22, 2025 am 08:57 AM

可以。兩個交易所之間可以互相轉幣,只要支持相同的幣種和網絡。步驟包括:1. 獲取收款地址,2. 發起提幣請求,3. 等待確認。注意事項:1. 選擇正確的轉賬網絡,2. 仔細核對地址,3. 了解手續費,4. 注意到賬時間,5. 確認交易所支持該幣種,6. 注意最小提幣數量。

Hashbeat應用:2025年受監管的最高加密雲採礦平台,並提供免費的比特幣採礦獎勵,並提供每日支出 Hashbeat應用:2025年受監管的最高加密雲採礦平台,並提供免費的比特幣採礦獎勵,並提供每日支出 Apr 21, 2025 pm 06:21 PM

2025年最值得投資的加密貨幣:無需盯盤的雲挖礦策略如果您想在2025年投資加密貨幣,又不想時刻關注市場波動,那麼雲挖礦或許是您的理想選擇。雲挖礦無需昂貴的礦機和復雜的設置,即可輕鬆生成比特幣和其他數字貨幣。 2025年湧現了一批新的雲挖礦平台,讓您比以往更容易上手。無論是新手小白還是追求被動收入的投資者,以下11個平台都值得關注。 Hashbeat應用:受監管的加密雲挖礦平台,提供免費比特幣挖礦獎勵,每日支付如果您希望在2025年進行低風險、高安全性、穩定回報的加密貨幣投資,Hashbeat應用

2025使用幣安教程 新手小白教程大全 2025使用幣安教程 新手小白教程大全 Apr 21, 2025 pm 09:51 PM

幣安新手教程包括註冊、登錄、核心功能介紹和安全設置。 1. 註冊與登錄:訪問官網註冊,填寫信息並驗證;下載APP並登錄。 2. 核心功能:首頁展示信息,交易包括現貨和合約,資產管理和更多功能。 3. 常用操作:充值、現貨交易、提現和劃轉。 4. 安全設置:完成KYC、開啟2FA、設置反釣魚碼和管理API密鑰。

十大數字虛擬幣交易app排行榜 十大數字貨幣交易所排行榜2025年 十大數字虛擬幣交易app排行榜 十大數字貨幣交易所排行榜2025年 Apr 22, 2025 pm 02:45 PM

數字貨幣交易所排名前十分別是:1. OKX,2. Binance,3. gate.io,4. Coinbase,5. Kraken,6. Huobi,7. KuCoin,8. Bitfinex,9. Bitstamp,10. Poloniex。這些交易所根據交易量、用戶體驗和安全性等因素評選,均提供多種數字貨幣交易服務和高效的交易體驗。

See all articles