0

はじめに: $_SESSION で PHP を学ぼうとしています。私がやろうとしていたのは、セッションを介して割り当てられた値を呼び出すことです。タブを閉じると、割り当てられた値が保持され、ブラウザでタブを開いたときにブラウザにエコーされます。

問題: コードに問題があり、何らかの理由でフォームに入力された値をエコーできませんでした。

フォームは次のようになります。

Name:_____________
Email:_____________ Remember me? __  SUBMIT

$_SESSION['name'] = "John" および $_SESSION['email'] = "someemail@email.com" は、ユーザーが "remember me" をクリックした場合のみになるようにしました。

ブラウザの「タブ」を閉じても、ブラウザ自体はエコーしない場合...

John
someemail@email.com

Here's your download link (some link here)...

もちろん、ブラウザを閉じると、セッションは失われます。Cookie を使用することはできますが、詳細を学ぶためのセッションに取り組んでいます。

以下のコードは実行されますが、何らかの理由で $_SESSION 変数から値をエコーできませんでした。

<?php 

 //Start session
    session_start(); 
    // session
    if (isset($_POST['remember'])) {

$customer_name = $_SESSION['name'];
if (!($customer_name)) {
$customer_name = $_POST['name'];
}
$customer_email = $_SESSION['email'];
if (!($customer_email)) {
$customer_email = $_POST['email'];
}

    }


//If form submit validate
    if (isset($_POST['Submit'])) {
    // Santize fields here but FILTER_VALIDATE_STRING isn't necessary as there is no absolute way 
    //to validate names absolutely 
    // Also shows error message if there's error 
    if ($_POST['name'] != "") {
        $_POST['name'] = filter_var($_POST['name'], FILTER_SANITIZE_STRING);
        if ($_POST['name'] == "") {
            $errors .= 'Please enter a valid first name.<br/><br/>';
        }
    } else {
        $errors .= 'Please enter your first name.<br/>';
    }

    // Sanitize and validate email
    // Error message shows if any
    if ($_POST['email'] != "") {
        $email = filter_var($_POST['email'], FILTER_SANITIZE_EMAIL);
        if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
            $errors .= "$email is NOT a valid email address.<br/><br/>";
        }
    } else {
        $errors .= 'Please enter your email address.<br/>';
    }


    // If no errors, submitted form is emailed
    if (!$errors) {

        echo "I did something!<br /><br />"; // might add some message
        //downloadLink();
        echo "<br /><br />";



    }




    } else {
        echo '<div id="error">' . $errors . '<br /></div>';
    }



?>

<form name="form1" method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
Name:
<?php
  if (isset($_SESSION['name'])) {
    echo $_SESSION['name']."<br />";
  }
else {
?> 
<input type="text" name="name" value="<?php echo $_POST['name']; ?>" size="25" /><br />
<?php } ?>

Email:
<?php
  if (isset($_SESSION['email'])) {
    echo $_SESSION['email']."<br /><br />";

    // echo link.. downloadLink();
  }
else {
?>  
<input type="text" name="email" value="<?php echo $_POST['email']; ?>" size="25"/> 
<input type="checkbox" name="remember" /> Remember me
<input type="submit" name="Submit" />
<?php } ?>


</form>
</div>
4

1 に答える 1