簡體   English   中英

如何使用PHP使表格發送電子郵件?

[英]How to use PHP to make a form send an email?

我已經學習PHP大約兩天了。 所以我真的是PHP新手。 我已經盡力理解了,但是無論我寫什么,我的代碼都無法正常工作。 我成功地發送了一封電子郵件。 但是我無法以它的形式發送內容。

這是我的HTML表單。

    <!-- FORM BEGINS -->

<form action="contact-form-handler.php" method="post">

<!-- Full Name -->

    <div class="formWrapper ">
        <label name="firstname" for="firstName"><span>*</span>First Name</label>
        <input type="text" name="memberFirstName" id="memberFirstName" onkeyup="activateButton()" class="inputText" tabindex="1" maxlength="256" onkeydown="return checkAlphaNumericText(event,this);" required="required"/>
    </div>

    <p class="fieldsetDivider"></p>

    <div class="formWrapper">
        <label for="lastName"><span>*</span>Last Name</label>
        <input type="text" name="memberLastName" id="memberLastName" onkeyup="activateButton()" class="inputText" tabindex="2" maxlength="256" onkeydown="return checkAlphaNumericText(event,this);" required="required"/>
    </div>

    <p class="fieldsetDivider"></p>

    <!-- Date of Birth-->

    <p class="fieldsetDivider"></p>

    <div class="formWrapper smallInput">
        <label for="firstInput"><span>*</span>Date of Birth
        <div class="labelClarify">(MM/DD/YYYY)</div>
        </label>        
        <div class="inlineInput">
            <input type="text"  name="month" id="month" maxlength="2" onkeyup="activateButton();autotab(this, 'day')" onkeypress="return isNumberKey(event)" class="inputText" placeholder="MM" required="required"/>
            <span>/</span>
        </div>      
        <div class="inlineInput">
            <input type="text"  name="day" id="day" maxlength="2" onkeyup="activateButton();autotab(this, 'year')" onkeypress="return isNumberKey(event)" class="inputText" placeholder="DD" required="required"/>
            <span>/</span> 
        </div>            
        <div class="inlineInput">
            <input type="text"  name="year" id="year" maxlength="4" onkeyup="activateButton()" onkeypress="return isNumberKey(event)" class="inputText" placeholder="YYYY" required="required"/>
        </div>              
        <a rel="Please enter your date of birth" class="formHelp tooltip-link" href="#">
            <img src="../../images/site3/common/form_icon_help.png">
        </a>
    </div>

    <p class="fieldsetDivider"></p>

    <!-- Member ID -->

    <div class="formWrapper">
        <label for="memberID"><span>*</span>Member ID</label>
     <div class="inlineInput">
        <input type="text" name="memberID" id="memberID" class="inputText" onkeyup="activateButton()" tabindex="3" maxlength="9" onkeypress="return isNumberKey(event)" required="required"/>
     </div>       
     <a rel="Please enter your member ID" class="formHelp tooltip-link" href="#">
        <img src="../../images/site3/common/form_icon_help.png">
        </a>
    </div>

    <p class="fieldsetDivider"></p>

    <!-- Zip Code -->

    <div class="formWrapper">
            <label for="zipCode"><span class="requiredStar">*</span>Zip Code</label>
            <div class="inlineInput">
            <input type="text" name="memberZipCode" id="memberZipCode" onkeyup="activateButton()" tabindex="4" class="inputText" maxlength="5" onkeypress="return isNumberKey(event)"/>
        </div>
    </div>

    <p class="fieldsetDivider"></p>

<!-- Button -->

    <div class="button">
        <button class="greenBtnLarge" type="submit" style="text-decoration:none;"><span>Next<span></button>
    </div>
</form>

<!-- FORM ENDS -->

有人可以幫我提供適用於此表單的php代碼嗎? 我在互聯網上找到了幾個模板表單,並且花了數小時試圖修改它們以使其與我的表單一起使用。 但是沒有運氣。

而且我可以使PHP和表單一起工作,並使其從服務器發送電子郵件給我,因此服務器沒有問題。 將會發送一封電子郵件。 我只是無法獲取PHP代碼來發送表單內容。 它發送電子郵件,但沒有表單詳細信息。 了解?

我真的非常需要這個方面的幫助。 你們可以幫我創建一個與該線程中發布的HTML表單一起使用的PHP代碼嗎? 我確實需要在這個項目中超越這一步。

謝謝!

更新!

這是我在互聯網上找到的PHP模板,但是我不知道如何正確地對其進行修改。

<?php 
$errors = '';
$myemail = 'example@example.com';//<-----Put Your email address here.
if(empty($_POST['firstname'])  || 
   empty($_POST['lastname']) || 
   empty($_POST['dob']))
{
    $errors .= "\n Error: all fields are required";
}

$name = $_POST['firstname']; 
$email_address = $_POST['lastname']; 
$message = $_POST['dob']; 

if (!preg_match(
"/^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,3})$/i", 
$email_address))
{
    $errors .= "\n Error: Invalid email address";
}

if( empty($errors))
{
    $to = $myemail; 
    $email_subject = "Contact form submission: $name";
    $email_body = "You have received a new message. ".
    " Here are the details:\n Name: $name \n Email: $email_address \n Message \n $message"; 

    $headers = "From: $myemail\n"; 
    $headers .= "Reply-To: $email_address";

    mail($to,$email_subject,$email_body,$headers);
    //redirect to the 'thank you' page
    header('Location: contact-form-thank-you.html');
} 
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
<html>
<head>
    <title>Contact form handler</title>
</head>

<body>
<!-- This page is displayed only if there is some error -->
<?php
echo nl2br($errors);
?>


</body>
</html>

您有幾個代碼錯誤...

1)從標題的<input type="text">刪除<label>標記...不需要它們。
2)例如,確保您的表單字段name與您的電子郵件代碼$_POST['something']相匹配
您的<input type="text" name="memberFirstName" id="memberFirstName" /><input type="text" name="memberFirstName" id="memberFirstName" /> ...但是您的電子郵件代碼中有$_POST['firstname'] $_POST更改$_POST memberFirstName或將您的<input名稱和ID更改為firstname

需要對所有元素進行相同的更改,以便它們精確匹配。

並且請記住... PHP區分大小寫。

編碼愉快!

HTML表單字段與php電子郵件處理程序中的字段不同

例如

輸入名稱應與處理程序應獲取的名稱相同

<input type="text" name="memberFirstName" required="required"/>

$ _POST的索引應該是相同的memberFirstName

$_POST['memberFirstName']

這應該應用於所有領域

似乎HTML表單與php處理程序完全無關。

最好使用此表格進行測試

<form action="contact-form-handler.php" method="POST">
    First Name: <input name="firstname" type="text"><br>
    Last Name:<input name="lastname" type="text"><br>
    DOB: <input name="dob" type="text">
    <button type="submit">Send</button>
</form>

注意:

如果您使用的是wamp或xampp本地服務器,則需要檢查電子郵件服務是否配置正確,否則將不發送電子郵件。檢查以供參考: 如何配置XAMPP從本地主機發送郵件?

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM