安全登录代码 php,php如何保证Cookie自动登录的安全性?

[php]代码库class member

{

var $ck='Dxe8SqIcmyUf';

var $db; //传入PDO对象

var $mid; //会员ID

public $scr; //cookie 安全码 $_COOKIE['scr']

public $user;//cookie User $_COOKIE['user']

public $srpwd;//执行checkcookie后方可调用

function __construct()

{

if(!empty($_COOKIE['scr']))

{

$this->scr = $_COOKIE['scr'];

}

if(!empty($_COOKIE['user']))

{

$this->user= $_COOKIE['user'];

}

}

/**

* 检测cookie

*/

public function checkcookie()

{

$uname = $this->user;

$hash = $this->scr;

if(!empty($uname) && !empty($hash))

{

if (preg_match("/[|#|$|%|^|*|(|)|{|}|'|\"|;|:]/i",$uname) || preg_match("/[|#|$|%|^|*|(|)|{|}|'|\"|;|:]/i",$hash))

{

$this->mid=0;

return false;

}

else{

$sql = "select username,password from users where username='$uname'";

$rs = $this->db->query($sql);

$row = $rs->fetch();

$scr = $this->makescr($row['username'],$row['password']);

if($hash == $scr)

{

$this->srpwd=$row['password'];

return true;

}

else {

return false;

}

}//cookie安全

}else {

return false;

}//exit

}//function checkcookie

/**

* putcookie

*

* 登陆成功后放置cookie,包含安全码

*

* @param String $uname

* @param String $pwd

* @param Int $time

*/

public function putcookie($uname,$pwd,$time = 604800)

{

try {

$scrString = $this->makescr($uname,$pwd);

if(!is_numeric($time))

{

$time = 604800;

}

setcookie('user',$uname,time()+$time,'/');

setcookie('scr',$scrString,time()+$time,'/');

return true;

} catch (Exception $e) {

return false;

}

}//function putcookie

/**

* 生成安全码

*

* @param String $u

* @param String $p

*/

public function makescr($u,$p)

{

return substr(md5($u.$p.$this->ck),3,20);

}

694748ed64b9390909c0d88230893790.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值