PHP 使用cookie实现记住登录状态
php使用cookie实现记住登录状态,本文用最原始的方法讲解如何实现记住登录状态,给出3个步骤和具体实现代码,需要的朋友可以参考下。
要实现记住密码自动登录的功能,我们大多数据都是利用了客户端的cookies来实现。
php制作记住密码自动登录的解决思路,其实也就是对session,cookies的操作
一、检查用户是否登录
<?php
// 检查用户是否登录
function checklogin() {
if (empty ( $_SESSION ["user_info"] )) // 检查一下session是不是为空
{
if (empty ( $_COOKIE ["username"] ) || empty ( $_COOKIE ["password"] ))
{
header ( "location:login.php?req_url=" . $_SERVER ["REQUEST_URI"] ); // 转到登录页面,记录请求的url,登录后跳转过去,用户体验好。
}
else
{
$user = getUserInfo ( $_COOKIE ["username"], $_COOKIE ["password"] ); // 去取用户的个人资料
if (empty ( $user ))
{
header ( "location:login.php?req_url=" . $_SERVER ["REQUEST_URI"] );
}
else {
$_SESSION ["user_info"] = $user; // 用户名和密码对了,把用户的个人资料放到session里面
}
}
}
}
?> 二,用户提交登录信息
<?php
$username = trim ( $_POST ["username"] );
$password = md5 ( trim ( $_POST ["password"] ) );
$remember = $_POST ["remember"];
$validatecode = $_POST ["validateCode"];
$ref_url = $_GET ["req_url"];
$err_msg = "";
if ($validatecode != $_SESSION ["checksum"]) {
$err_msg = "验证码不正确";
} elseif ($username == "" || $password == "") {
$err_msg = "用户名和密码都不能为空";
} else {
$row = getUserInfo ( $username, $password );
if (empty ( $row )) {
$err_msg = "用户名和密码都不正确";
} else {
$_SESSION ["user_info"] = $row;
if (! empty ( $remember )) { // 如果记住登陆,则记录登录状态,把用户名和加密的密码放到cookie里面
setcookie ( "username", $username, time () + 3600 * 24 * 365 );
setcookie ( "password", $password, time () + 3600 * 24 * 365 );
}
if (strpos ( $ref_url, "login.php" ) === false) {
header ( "location:" . $ref_url );
} else {
header ( "location:main_user.php" );
}
}
}
?> 三,当用户点退出时,清出记录登录状态
<?php
// 退出登录
function logout()
{
unset ( $_SESSION ["user_info"] );
if (! empty ( $_COOKIE ["username"] ) || ! empty ( $_COOKIE ["password"] ))
{
setcookie ( "username", null, time () - 3600 * 24 * 365 );
setcookie ( "password", null, time () - 3600 * 24 * 365 );
}
}
?>四、简洁版实例
<?
// 读取COOKIE的用户名和密码的值即可
if ($_COOKIE ["uname"] != "") {
$CKUNAME = $_COOKIE ["uname"];
}
if ($_COOKIE ["pwd"] != "") {
$CKPWD = $_COOKIE ["pwd"];
}
echo $CKUNAME;
echo "<br>";
echo $CKPWD;
?>
<form id="form1" name="form1" method="post" action="">
<input type="text" name="uname" id="uname" value="<?=$CKUNAME;?>" />
<input type="password" name="pwd" id="pwd" value="<?=$CKPWD;?>" />
<input name="remember" type="checkbox" value="1" <? if($CKUNAME!=""){?> checked="checked" <? } ?> /> 记住我!
<input type="submit" name="button" id="button" value="登录" />
</form>
<?
// 登录,将用户名和密码存入到COOKIE
if ($_POST ["button"] != "")
{
$uname = $_POST ["uname"];
$pwd = $_POST ["pwd"];
// 如果输入的加密密码和COOKIE中不一样,那么就加密
if ($pwd != $CKPWD) {
$pwd = md5 ( $pwd );
}
$remember = $_POST ["remember"];
if ($remember == 1) {
setcookie ( "uname", $uname, time () + 3600 * 24 * 30 );
setcookie ( "pwd", $pwd, time () + 3600 * 24 * 30 );
}
}
?>声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
