PHP会话变量消失?

PHP会话变量消失?,php,session,variables,Php,Session,Variables,我有3个页面,login.php、login_validate.php和userhome.php。我的问题是登录信息被正确地传递到login_validate.php,但是当login_validate重定向到userhome.php时,它似乎消失了 任何帮助都将不胜感激 Login.php <form name="login" action="login_validate.php" method="post"> Username: <input type="text"

我有3个页面,login.php、login_validate.php和userhome.php。我的问题是登录信息被正确地传递到login_validate.php,但是当login_validate重定向到userhome.php时,它似乎消失了

任何帮助都将不胜感激

Login.php

<form name="login" action="login_validate.php" method="post">
    Username: <input type="text" name="myusername" /><br />
    Password: <input type="password" name="mypassword" /><br />
    <input type="submit" value="Login" />
</form>

用户名:
密码:
login_validate.php(我知道,它很长)


userhome.php



您需要在每个使用会话的脚本中调用session\u start()(在发送头之前)。

您是否在login\u validate.php中的任意位置调用
session\u start()
?@user1436735您认为不必这样做的原因是什么?这有点让人困惑。如果PHP找不到变量,它会自动创建它,因此当他在第一页访问
$\u SESSION
时,它似乎已经在那里了。容易犯错误!这就是为什么它看起来像是保存了数据,而实际上它创建了一个
$\u SESSION
变量,该变量实际上对SESSION没有任何作用:)
<?php

  include'connect.php';

  // username and password sent from form
  if(isset($_POST['myusername']) and isset($_POST['mypassword'])){
    $myusername=$_POST['myusername'];
    $mypassword=$_POST['mypassword'];
  }else{
    header('Location:login.php?failatvalidate');
  }
  // To protect MySQL injection (more detail about MySQL injection)
  $myusername = stripslashes($myusername);
  $mypassword = stripslashes($mypassword);
  $myusername = mysql_real_escape_string($myusername);
  $mypassword = mysql_real_escape_string($mypassword);

  $mypassword = hash('sha256', $mypassword);

  $sql="SELECT * FROM users WHERE username='$myusername' and password='$mypassword'";
  $result=mysql_query($sql);

  // Mysql_num_row is counting table row
  $count=mysql_num_rows($result);

  // If result matched $myusername and $mypassword, table row must be 1 row

  if($count==1){

  // Register $myusername, $mypassword and redirect to file "userhome.php"
  $_SESSION['myusername'] = $myusername;
  $_SESSION['mypassword'] = $mypassword;

  print '<pre>';
  var_dump($_SESSION);
  print '</pre>';

  echo "<a href='userhome.php'>Home</a>";
  }
  else {
    echo "Wrong Username or Password";
  }
?>
<?php
  error_reporting(E_ALL ^ E_NOTICE);
  ini_set('display_errors',1);

  session_start();
  if(!isset($_SESSION['myusername'])){
    echo "error :( ";
  }else{
    echo "Logged in as ".$_SESSION['myusername']."&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp<a href='logout.php'>Log out</a><br /><br />";
  }
?>