1

したがって、以下のこのPHPコードを使用して、Imは電子メールを送信しようとしています。何らかの理由で、HTMLの連絡先ページで[送信]ボタンをクリックすると、phpで両方のエラーが発生します。

Error: all fields are required Error: Invalid email address

そして、私はそれが適切な電子メールであり、すべてのフィールドが入力されていることを知っています。99%は、すべての入力フィールドがHTMLファイルで適切な名前であることを確認しています。これがPHPコードです。

<?php 
$errors = '';
$myemail = 'support@Blocked for security.host22.com';//<-----Put Your email address here.
if(empty($_POST['name'])  || 
   empty($_POST['email']) || 
   empty($_POST['message']))
{
    $errors .= "\n Error: all fields are required";
}

$name = $_POST['name']; 
$email_address = $_POST['email']; 
$message = $_POST['message']; 

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);
} 
?>
<!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>

フォームのHTML:

            <form action="contact-form-handler.php" method="POST" enctype="text/plain" name="contactform">
            <label for='name'>Name:</label><br/><input type="text" name="name"><br/>
            <label for='email'>Email:</label><br/><input type="text" name="email"><br/>
            <label for='message'>Message:</label><br/><textarea name="message" cols=48 rows=4></textarea><br/>
            <input type="submit" name="submit" value="Send">
        </form>
4

2 に答える 2

1

あなたのフォームの問題はここにあります:

enctype="text/plain"

PHPが変数をに入れるには、変数を削除するか、またはのいずれかに等しくする必要があり$_POSTます。enctypeapplication/x-www-form-urlencodedmultipart/form-data

于 2012-10-19T02:03:52.323 に答える
0

したがって、メールアドレス!preg_match。私は個人的に、人々が実際の電子メールアドレスを入力していることを検証するために正規表現を使用しようとはしません。SMTP自体からの検証になります。

少なくとも今のところ、コードのこのセクションを削除するだけです。

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";
}

次に、スクリプトを再実行すると、正規表現が問題であることがわかります。うまくいけば、あなたは人々があなたが送っている電子メールを本当に受け取りたいと思うような方法でこのスクリプトを使用しています。その場合、私が気にするのは、フォームに2回入力してメールアドレスを確認することです。

于 2012-10-19T01:52:01.460 に答える