php登录类,php 用户登录专用类示例

这篇文章主要为大家详细介绍了php 用户登录专用类示例,具有一定的参考价值,可以用来参考一下。

这是一个用于登录的php类,包含了数据库调用,写入cookie,感兴趣的小伙伴,下面一起跟随512笔记的小编罗X来看看吧。

经测试代码如下:

/**

* 用于登录的php类:数据库调用,写入cookie

*

* @param

* @arrange (512.笔记) www.512pic.com

**/

class Auth

{

var $user_id;

var $username;

var $password;

var $ok;

var $salt = "34asdf34";

var $domain = ".domain.com";

function Auth()

{

global $db;

$this->user_id = 0;

$this->username = "Guest";

$this->ok = false;

if(!$this->check_session()) $this->check_cookie();

return $this->ok;

}

function check_session()

{

if(!empty($_SESSION['auth_username']) && !empty($_SESSION['auth_password']))

return $this->check($_SESSION['auth_username'], $_SESSION['auth_password']);

else

return false;

}

function check_cookie()

{

if(!empty($_COOKIE['auth_username']) && !empty($_COOKIE['auth_password']))

return $this->check($_COOKIE['auth_username'], $_COOKIE['auth_password']);

else

return false;

}

function login($username, $password)

{

global $db;

$db->query("SELECT user_id FROM users WHERE username = '$username' AND password = '$password'");

if(mysql_num_rows($db->result) == 1)

{

$this->user_id = mysql_result($db->result, 0, 0);

$this->username = $username;

$this->ok = true;

$_SESSION['auth_username'] = $username;

$_SESSION['auth_password'] = md5($password . $this->salt);

setcookie("auth_username", $username, time()+60*60*24*30, "/", $this->domain);

setcookie("auth_password", md5($password . $this->salt), time()+60*60*24*30, "/", $this->domain);

return true;

}

return false;

}

function check($username, $password)

{

global $db;

$db->query("SELECT user_id, password FROM users WHERE username = '$username'");

if(mysql_num_rows($db->result) == 1)

{

$db_password = mysql_result($db->result, 0, 1);

if(md5($db_password . $this->salt) == $password)

{

$this->user_id = mysql_result($db->result, 0, 0);

$this->username = $username;

$this->ok = true;

return true;

}

}

return false;

}

function logout()

{

$this->user_id = 0;

$this->username = "Guest";

$this->ok = false;

$_SESSION['auth_username'] = "";

$_SESSION['auth_password'] = "";

setcookie("auth_username", "", time() - 3600, "/", $this->domain);

setcookie("auth_password", "", time() - 3600, "/", $this->domain);

}

}

/*** 代码来自512笔记(www.512pic.com) ***/

注:关于php 用户登录专用类示例的内容就先介绍到这里,更多相关文章的可以留意512笔记的其他信息。

关键词:用户登录

您可能感兴趣的文章

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值