【问题标题】:Displaying user name and user id from $_SESSION [closed]显示来自 $_SESSION 的用户名和用户 ID [关闭]
【发布时间】:2013-11-15 18:56:04
【问题描述】:

我一直无法回显我的$_SESSION['user_name']。我注意到如果我删除“!”从判断是否登录的表单中的if语句中,它在第二次登录后起作用:

if(!isset($_SESSION['LOGIN_STATUS'])

但是,尽管这对我来说毫无意义,但它也会禁用注销功能,因此我尽量避免这种情况。我还想知道将用户名填充到单独的表单中是否存在问题。

我也无法使用$_SESSION['user_id'] 返回任何值。我尝试了很多方法,包括使用 PDO::FETCH_NUM 检查拼写和验证我的表凭据,但仍然没有。

到目前为止,验证适用于用户名和密码,但在当前代码中回显 $_SESSION['user_name']$_SESSION['user_id'] 时没有返回任何内容:

PHP:

<?php
session_start();
require_once('php/config.php');

if(isset($_POST['submit'])){
  $username = $_POST['user_name'];
  $password = $_POST['pwd'];

  $stmt = $con->prepare("SELECT * FROM tapp_login WHERE username = ? AND password = ? LIMIT 1");
  $stmt->bind_param('ss', $username, $password);
  $stmt->execute();
  $stmt->bind_result($username, $password);
  $stmt->store_result();
  if($stmt->num_rows == 1){  //To check if the row exists
    $row = $stmt->fetch(PDO::FETCH_NUM); //fetching the contents of the row
    $_SESSION['LOGIN_STATUS']=true;
    $_SESSION['user_id'] = $row['user_id'];
    $_SESSION['user_name'] = $username;              
    echo 'true';  
  }
  else {
    echo 'false';
  }
  $stmt->close();
}
else{
}
$con->close();
?>

表格:

<body>
<fieldset id="login_form_wrap" class="login_form_header">
  <legend><a href='projects.php'>CUSTOMER LOGIN</a></legend>
  <?php session_start();
  $_SESSION['timeout'] = time();?>
  <div id="profile"> 
  <!--If not logged in-->  
  <?php if(!isset($_SESSION['LOGIN_STATUS']) || ($_SESSION['timeout'] + 600 < time())){?>
    <div id="login_a">
      <a id="login_profile" href="#">click to login</a>
    </div>
  <!--Else if logged in-->
  <?php }else {;?>
  <a href='logout_session.php' id='logout'>Logout</a>
  <!--header('location: dashboard.php');-->
  <?php } ?>
  </div>
  <form action="login_validation.php" id="login_form" method="POST">
    <div id="login_b">
      <div class="welcome"></div>
      <span class="col1">USER NAME:</span>
      <input type="text" id="user_name" name="user_name" class="input" required />
      <span class="col1">PASSWORD:</span>
      <input type="password" id="password" name="password" class="input" required />
      <span class="col1"></span>
      <input type="submit" name"submit" id="login_validation" value="SUBMIT" />
      <input type="reset" id="cancel_hide" value="CANCEL" />
      <div id="add_err"><br></div>
    </div>
  </form>
  <form action="project_validation.php" id="projects_form" method="POST">
  <div id="projects">

    <!-------------------------- Does not work ------------------------->
    <div class="welcome">Welcome <?php echo $_SESSION['user_name'];?><br>
    User ID: <?php echo $_SESSION['user_id'];?></div>  


    <span class="col1">PROJECTS:</span>
    <select id="Projects" name="Projects" class="input">
    <option id="project" name="project" value="" selected="selected" disabled='disabled'>Choose a Project...</option>

    ...

    </select>  
  </div>
  <span class="col1"></span>          
  <input type="submit" name="select" id="project_validation" value="SELECT" />
  <div id="add_err"><br></div> 
  </form>
</fieldset>
</body>

如果您想知道“...”只是代表更多不必要的形式。

【问题讨论】:

  • 你需要先学习基础知识。
  • @relentless 也许是这样。我是新来的,只是在寻找正确的方向。
  • 我这么说不是为了劝阻你,我这么说是因为你的问题太大了,无法在这里回答。继续尝试。阅读一些教程,观看视频等...

标签: php mysql session


【解决方案1】:

来自 PHP 官方文档:

要使用基于 cookie 的会话,必须在向浏览器输出任何内容之前调用 session_start()。

在表单页面中,在内容发送到输出后调用 session_start。您必须在编写 HTML 之前调用 session_start。

【讨论】:

    猜你喜欢
    • 2019-12-20
    • 1970-01-01
    • 2021-09-14
    • 1970-01-01
    • 2022-01-05
    • 2014-12-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多