2016-05-22 14 views
0

私は現在自分の選択したアプリケーション(この場合はwp/wp)からデータベースにアクセスするはずの学校プロジェクトに取り組んでおり、問題が発生しました。私の関数NewUser()では、いったんアカウントが作成されると、ログインウィンドウにポップアップするメッセージが表示されます(スウェーデン語なので、心配しないでください)。問題はこれです: セッションは何らかの形で(この場合はサーバーを再起動して)再起動するまで削除されませんが、これは本当に最適ではありません。セッション変数を最も効率的に取り消すにはどうすればよいですか?

たとえば、ページがリロードされるたびにメッセージが削除されるようにしたいと思いますか?

あなたが与えることができる助けが役に立ちます、そして、私は単にページがリロードされたときに、セッションを閉じるための最良の方法は何ですか?

敬具、 ビクター

<?php 
session_start(); 

ini_set("display_errors", true); 
error_reporting(E_ALL); 

include('connect.php'); 

function NewUser() 
{ 
    global $email; 
    $firstname = $_POST['firstname']; 
    $lastname = $_POST['lastname']; 
    $pnumber = $_POST['pnumber']; 
    $age = $_POST['age']; 
    $email = $_POST['email']; 
    $password = password_hash($_POST['password'], PASSWORD_DEFAULT); 

    global $mysqli; 
    $stmt = $mysqli->prepare("INSERT INTO persons (firstname, lastname, pnumber, age, email, pwd) 
          VALUES (?,?,?,?,?,?)"); 
    $stmt->bind_param('ssssss', $firstname, $lastname, $pnumber, $age, $email, $password); 
    $stmt->execute(); 
    if ($mysqli) 
    { 
    $_SESSION['accountCreated'] = "Ditt konto har skapats, du kan nu logga in!"; 
    header("Location:index.php"); 
    exit(); 
    } 
    else 
    { 
     echo ("<script type='text/javascript'> 
     window.alert('Oj, det blev något fel i registreringen! Försök igen'); 
     window.location = 'index.php'; 
     </script>"); 
     exit(); 
    } 
} 

function SignUp() 
    { 
    if(!empty($_POST['email'])) 
    { 
    global $mysqli; 
    $query = ("SELECT * FROM persons WHERE email = ?"); 
    if ($stmt = $mysqli->prepare($query)) 
    { 
     $stmt->bind_param('s', $_POST['email']); 
     $stmt->execute(); 
     $stmt->store_result(); 
     $countRows = $stmt->num_rows; 
     $stmt->close(); 
    } 

    if($countRows < 1) 
    { 
    $_SESSION['emailExistsError'] = ""; 
    $_SESSION['message'] = "success"; 
    NewUser(); 
    } 
    else 
    { 
    $_SESSION['accountCreated'] = ""; 
    $_SESSION['emailExistsError'] = "Denna mejladdressen har redan använts!"; 
    $_SESSION['message'] = "error"; 
    header("Location:index.php"); 
    exit(); 
    } 

} 
} 
    if(isset($_POST['submit'])) 
    { 
    $close = false; 

    if(empty($_POST["firstname"])) 
    { 
     $_SESSION['fnameError'] = "Du måste fylla i ditt förnamn!"; 
     $close = true; 
    } else { 
     $_SESSION['fnameError'] = ""; 
    } 
    if(empty($_POST["lastname"])) 
    { 
     $_SESSION['lnameError'] = "Du måste fylla i ditt efternamn!"; 
     $close = true; 
    } else { 
     $_SESSION['lnameError'] = ""; 
    } 
    if(empty($_POST["email"])) 
    { 
     $_SESSION['emailError'] = "Du måste fylla i din e-mail!"; 
     $close = true; 
    } else { 
     $_SESSION['emailError'] = ""; 
    } 
    if(empty($_POST["password"])) 
    { 
     $_SESSION['passwordError'] = "Du måste fylla i ett lösenord!"; 
     $close = true; 
    } else { 
     $_SESSION['passwordError'] = ""; 
    } 
    if(empty($_POST["pnumber"])) 
    { 
     $_SESSION['pnumberError'] = "Du måste fylla i ditt personnummer!"; 
     $close = true; 
    } else { 
     $_SESSION['pnumberError'] = ""; 
    } 
    if(empty($_POST["age"])) 
    { 
     $_SESSION['ageError'] = "Du måste fylla i din ålder!"; 
     $close = true; 
    } else { 
     $_SESSION['ageError'] = ""; 
    } 

    if($close == true) { 
     header("Location:index.php"); 
     exit(); 
    } else { 
     SignUp(); 
    } 
    } 
$mysqli->close(); 
?> 

答えて

4

はい、単にunsetを使用します。

unset($_SESSION['message']);

あなたはすべてのセッションデータを削除したい場合は(私はあなたが欲しいとは思わないもの)、あなたの意図に応じてsession_destroy()またはsession_unset()を使用することができます。

+0

申し訳ありませんが、十分に簡単です。 Okeyは、ページがリフレッシュされるたびにそれを実行する関数内でそれを実装する方法はありますか? – Marante

+0

おそらく関数は必要ありません。メッセージを印刷した直後は、設定を解除することができます。 – rjdown

+0

しかし、その直後にunsetを使用すると、メッセージは表示されません。 – Marante

関連する問題