当用户登录时显示“注销”按钮,当他不使用 PHP/MySQL 时显示“连接”

Posted

技术标签:

【中文标题】当用户登录时显示“注销”按钮,当他不使用 PHP/MySQL 时显示“连接”【英文标题】:display the "logout" button when the user is logged in and 'connect' when he is not with PHP/MySQL 【发布时间】:2018-12-16 11:12:06 【问题描述】:

layout.phtml

<?php if (isset($_SESSION['user']) && ($_SESSION['user'] == false)): ?>
    <p>Hello </p>
    <a href="logout.php">Logout</a>
<?php else: ?>
    <a href="register.php">Sign up</a>
    <a href="userconnect.php">Connect</a>
<?php endif; ?>

我想在用户登录时显示logout按钮,在用户未登录时显示connect按钮。但是当发送表单数据时,它只显示connect按钮。

userconnect.phtml

有这个html表单。

<div class="user-connect">
  <?php if (isset($message))  echo $message;  ?>
    <form action="userconnect.php" method="post">
        <ul>
            <li>
                <label for="email"></label>
                <input type="text" id='email' name='email'>
            </li>
            <li>
                <label for="password"></label>
                <input type="password" id='password' name='password'>
            </li>
            <li>
                <input type="submit" name="enter">
            </li>
        </ul>
    </form>
</div>

userconnect.php

<?php

session_start();

if(isset($_POST["enter"]) && !empty($_POST["enter"])) 
    if(!empty($_POST['email']) && !empty($_POST['password'])) 
    
        $email = htmlspecialchars($_POST['email']);
        $password = htmlspecialchars(md5(md5($_POST['password'])));

        include ("connection.php");
        $query = $db->prepare('SELECT ID, email, password, firstName FROM user WHERE email = ?');
        $query->execute([$_POST['email']]);
        $user = $query->fetch();  

        if ($user) 
            if($_POST['password'] == $user['password'] && $_POST['email'] == $user['email'])
            
                $_SESSION['user'] = [
                    'email' => $user['email'],
                    'id' => $user['ID'] 
                ];
            
            $message = "Vous etes connectez!";
         else 
            $message = "Invalide email ou mot de passe!";
        
     else 
        $message = "Champs obligatoire a saisir";
    


$template = 'userconnect';
include 'layout.phtml';

转储$_SESSION['user']

<?php var_dump(isset($_SESSION['user'])); ?> 

显示bool(false)

您能帮我如何显示logout 按钮吗?

我到处搜索,但找不到解决方案。

【问题讨论】:

您是否在进行比较的其他页面上开始会话? 另外htmlspecialchars 应该只用于输出到浏览器。并且您应该使用比md5 更新的散列算法(加倍它不会使其更安全)。您也不需要$_POST['email'] == $user['email'],因为 SQL 已经验证了匹配。 你需要把if($_POST['password'] == $user['password'])改成这个:if( $password == $user['password']) @user3783243 如果我在显示的另一个页面上启动会话注意:会话已经开始 - 忽略 session_start() 【参考方案1】:

有个小问题。如果用户已登录,$_SESSION['user'] 不能是false。试试这样:

layout.phtml

<?php if (isset($_SESSION['user'])): ?>
    <p>Hello </p>
    <a href="logout.php">Logout</a>
<?php else: ?>
    <a href="register.php">Sign up</a>
    <a href="userconnect.php">Connect</a>

【讨论】:

【参考方案2】:

第一件事

替换

if($_POST['password'] == $user['password'] && $_POST['email'] == $user['email']

if($password == $user['password'])

您不需要检查$_POST['email'] == $user['email'],因为您已经在查询中使用WHERE 子句进行了检查,因此您只会得到与您在POST 请求中发送的电子邮件相匹配的结果。因此,一旦查询返回匹配的结果(电子邮件),指定 $_POST['email'] == $user['email'] 就没有用了。

然后,您应该使用$password 而不是$_POST['password'],因为您已将密码字段处理为带有一些散列的$password 变量。

第二件事

不要对用户输入使用htmlspecialcharshtmlentities。仅当您在页面上输出内容以防止诸如XSS 之类的攻击时才重要。

另外,我想知道您的密码在注册过程中是如何处理的。

更新

正如您在评论中提到的,您在注册期间使用password_hash 函数对密码进行哈希处理。

但在问题中,您使用md5(md5($_POST['password'])) 对输入进行哈希处理,并与数据库中的哈希密码进行匹配。这行不通。

相反,您应该使用password_verify,它旨在将输入与password_hash 生成的散列密码相匹配。

这里是你需要如何使用它,

$password = $_POST['password'];

if ($user) 
    if(password_verify($password, $user['password'])) 
        $_SESSION['user'] = [
            'email' => $user['email'],
            'id' => $user['ID'] 
        ];
        $message = "Vous etes connectez!";
    

顺便说一句,你把这个声明,

$message = "Vous etes connectez!";

密码验证条件里面。

就是这样。

希望对你有帮助!

【讨论】:

$password = password_hash($_POST['password'], PASSWORD_BCRYPT); $query = $db -> prepare('INSERT INTO user(firstName, lastName, password, email, address,birthday, city, postalCode, country, phoneNumber) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?)'); $query -> execute([ $firstName, $lastName, $password, $email, $address, $birthday, $city, $postalCode, $country, $phoneNumber]); 修改了答案。您现在可以查看了。 感谢您的回答。错误还在于未将 UNIQUE 索引分配给数据库中的电子邮件。 哦。是的。如果列不需要重复,则必须为 email 列分配 UNIQUE 索引。

以上是关于当用户登录时显示“注销”按钮,当他不使用 PHP/MySQL 时显示“连接”的主要内容,如果未能解决你的问题,请参考以下文章

用户登录时不显示表单,但用户注销时显示

如何使用php在注销时删除浏览器的本地存储项

不知何故,某些 css 仅在用户登录时显示 - 而对已注销的用户不显示。 HTML/CSS

如何在用户注销时隐藏侧边栏并在用户登录时显示侧边栏?

根据状态动态更改登录/注销按钮

未登录用户 Woocommerce,重定向