1. 程式人生 > >PHP基礎回顧之E-mail(四)

PHP基礎回顧之E-mail(四)

PHP的mail()函式

PHP 簡易 E-Mail 通過 PHP 傳送電子郵件的最簡單的方式是傳送一封文字 email。

<?php
$to = "[email protected]";         // 郵件接收者
$subject = "引數郵件";                // 郵件標題
$message = "Hello! 這是郵件的內容。";  // 郵件正文
$from = "[email protected]";   // 郵件傳送者
$headers = "From:" . $from;         // 頭部資訊設定
mail($to,$subject,$message,$headers);
echo "郵件已傳送";
?>

PHP Mail 表單 通過 PHP,可以在自己的站點製作一個反饋表單。下面的例項向指定的 e-mail 地址傳送了一條文字訊息:

<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
<?php
if (isset($_REQUEST['email'])) { // 如果接收到郵箱引數則傳送郵件
// 傳送郵件
    $email = $_REQUEST['email'] ;
    $subject = $_REQUEST['subject'] ;
    $message = $_REQUEST['message'] ;
    mail("
[email protected]
", $subject, $message, "From:" . $email); echo "郵件傳送成功"; } else { // 如果沒有郵箱引數則顯示錶單 echo "<form method='post' action='mailform.php'> Email: <input name='email' type='text'><br> Subject: <input name='subject' type='text'><br> Message:<br> <textarea name='message' rows='15' cols='40'> </textarea><br> <input type='submit'> </form>"; } ?> </body> </html>

PHP 防止 E-mail 注入 防止 e-mail 注入的最好方法是對輸入進行驗證。增加檢測表單中 email 欄位的輸入驗證程式:

<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
<?php
function spamcheck($field)
{
    // filter_var() 過濾 e-mail
    // 使用 FILTER_SANITIZE_EMAIL
    $field=filter_var($field, FILTER_SANITIZE_EMAIL);
    //filter_var() 過濾 e-mail
    // 使用 FILTER_VALIDATE_EMAIL
    if(filter_var($field, FILTER_VALIDATE_EMAIL))
    {
        return TRUE;
    }
    else
    {
        return FALSE;
    }
}

  if (isset($_REQUEST['email']))

{ // 如果接收到郵箱引數則傳送郵件

    // 判斷郵箱是否合法
    $mailcheck = spamcheck($_REQUEST['email']);
    if ($mailcheck==FALSE)
    {
        echo "非法輸入";
    }
    else
    {    
        // 傳送郵件
        $email = $_REQUEST['email'] ;
        $subject = $_REQUEST['subject'] ;
        $message = $_REQUEST['message'] ;
        mail("[email protected]", "Subject: $subject",
        $message, "From: $email" );
        echo "Thank you for using our mail form";
    }
}
else
{ 
    // 如果沒有郵箱引數則顯示錶單
    echo "<form method='post' action='mailform.php'>
    Email: <input name='email' type='text'><br>
    Subject: <input name='subject' type='text'><br>
    Message:<br>
    <textarea name='message' rows='15' cols='40'>
    </textarea><br>
    <input type='submit'>
    </form>";
}
?>

</body>
</html>