1

訪問者なら誰でもニュースレターを購読できる Web サイトを持っています。ページを更新するたびに再送信されるという問題が発生しました。PRG の概念を適用して解決しました。ユーザーが同じフォームを 2 回送信することはありません。問題が 1 つだけあります。成功または失敗したときに、入力フィールドの下にメッセージが表示されるようにフォームを設計しました。残念ながら、PRG の概念を適用した今、メッセージが表示されません。何をすべきか ?

index.php - 送信フォームとメッセージ表示を含む div があります。

        <div id="newsletter" >
            <form id="abonat" name="abonat" action="formular.php" method="post" onsubmit="return golire()" autocomplete="on"  > 
            <span>Subscribe</span>
            <input type="text" id="nume" name="nume"  placeholder="Name" required />
            <input type="email" id="email" name="email" placeholder="Email" autocomplete="off"  required/> 
            <input type="submit" value="Subscribe" class="button" style="width:26%;float:left;" /> 

            </form>
    </div>  

    <div id="mesaj_newsletter">
        <span><?php if (isset($mesaj)) echo $mesaj; ?> </span>
    </div> 

formular.php - 検証が行われ、メッセージが決定される場所

include('conect.php');    
function validEmail($email){
    //code that verifies if it is a valid email adress
}

if( (isset($_POST['email']))&&(isset($_POST['nume'])) ){
    $nume=mysql_real_escape_string($_POST['nume']);
    $email=mysql_real_escape_string($_POST['email']);
    $z=1;
    if(validEmail($email)==TRUE){
        $result=mysql_query("SELECT * FROM abonat");
        while($data=mysql_fetch_row($result)){
                if(($data[1]==$email)||($data[2]==$nume))
                    $z=0;
        }

        if($z==1){
           mysql_query("INSERT INTO abonat(email,nume) VALUES ('$email','$nume')");
           $mesaj="Your email has been registered";
        }
        else $mesaj="You are already registered";   
    }
    else $mesaj="You have not entered a valid email adress";
}
mysql_close($con);
header('Location:index.php');
?>
4

2 に答える 2