如何使我的php网站能够告诉用户是否登录?
我想显示一个链接到"我的帐户"而不是"登录"。
交货。用户进入首页,点击右上角的"登录",登录后再次浏览首页时显示的是"我的账号"而不是"登录"。
这是登录按钮的样子。如果用户登录,我希望能够将其替换为"我的帐户"。
https://i.stack.imgur.com/8xCDB.png更新:这是我现在试图使用的代码。它在69/72行给我错误
<form action="scripts/login.php" id="login-form">
<fieldset>
<?php
if(isset($_SESSION['name_of_user']))
{
**LINE 69** <a href="your_account.php" class="login" onClick="submit"><span><span>My Account</span></span></a><span class="links"><a href="reset-pwd-req.php">Forgot Password?</a><br/><a href="create_account.php">Register</a></span> }
}
else{
**LINE 72** <a href="general_login.php" class="login" onClick="submit"><span><span>Login</span></span></a><span class="links"><a href="reset-pwd-req.php">Forgot Password?</a><br/><a href="create_account.php">Register</a></span> }
?>
所以你需要使用会话来做到这一点。
首先你在php文件的顶部调用它:
session_start();
要启动会话,可以设置$_SESSION
变量。当用户登录时,可以设置(例如):
$_SESSION['user_name'] = "Lucas Weir";
然后在下一个php脚本中你可以这样做:
if(isset($_SESSION['user_name'])){
// user is logged in, hide the button here
} else {
// user is not logged in, show the login button
}
会话并不复杂,但值得研究。这是使用会话的一种非常基本的方式,但它一点也不安全。老实说,我很惊讶您已经设法创建了一个完整的用户登录/身份验证脚本,而不使用会话。;)
编辑:更多的信息。
会话存储在服务器上。它们与饼干"相似"。会话令牌存储在客户端计算机上的cookie中。然后使用它来交叉引用存储在服务器上的会话信息。
由于会话令牌(会话id)存储在客户端计算机上,它可以在每次加载另一个脚本时发送它。这意味着当您使用$_SESSION['name'] = "value";
设置会话变量时,可以在下一个调用的脚本上检索相同的值。
有关更多信息和一些示例/教程,请查看这里:http://www.w3schools.com/php/php_sessions.asp