php 登陆验证,PHP 验证登陆类分享

这是一个简单的PHP登录类实现,包含登录、登出、验证会话和Cookie的功能。类中设置了数据库配置和Cookie参数,并使用了加密方法确保安全性。通过检查会话和Cookie来判断用户是否已登录,同时在登录成功后将信息存储在会话和Cookie中。
摘要由CSDN通过智能技术生成

简单的登录类,没有把登录和数据库查询分开

/*

*   例子

*

*  $Auth=new Auth();

*  $Auth->login("123@123.com","123");

*  $Auth->logout();

*  echo $r->init();

*

**/

验证登陆类

/*

*

* @ID:      验证登陆类

*

* @class:   Auth.class.php

*

* @auther:  欣儿

*

* @time:    2015/03/12

*

* @web:     http://my.oschina.net/xinger

*

**/

class Auth {

//外部设置

//cookie设置

var $cookie_time;//         7200

var $cookie_where;//        '/'

var $cookie_domain;//       'yourweb.com'

var $cookie_secure;//       1和0

//数据库设置

var $select_uid;//          'uid'

var $select_table;//        'user'

var $select_usersname;//    'email'

var $select_password;//     'password'

//盐

var $salt;//                "12332"

var $guest_name;//          'Guest'

//用户获取值

var $user_id;

var $username;

var $ok;

var $pre;//                 'auth_'

var $depr;//                '-'

//内部变量

private $pre_username;

private $pre_password;

public function __construct($config=array()){

$this->set($config);

$this->pre_username=sha1(md5($this->pre.'username'));

$this->pre_password=sha1(md5($this->pre.'password'));

}

public function set($config){

$this->cookie_time       = isset($config['cookie_time'])?$config['cookie_time']: 7200;

$this->cookie_where      = isset($config['cookie_where'])?$config['cookie_where']:'/';

$this->cookie_domain = isset($config['cookie_domain'])?$config['cookie_domain']:'';

$this->cookie_secure = isset($config['cookie_secure'])?$config['cookie_secure']:'';

$this->select_uid        = isset($config['select_uid'])?$config['select_uid']:'uid';

$this->select_table      = isset($config['select_table'])?$config['select_table']:'table';

$this->select_usersname  = isset($config['select_usersname'])?$config['select_usersname']:'user_name';

$this->select_password   = isset($config['select_password'])?$config['select_password']:'password';

$this->salt              = isset($config['salt'])?$config['salt']:'sghsdghsdg';//

$this->guest_name        = isset($config['guest_name'])?$config['guest_name']:'Guest';//

$this->pre               = isset($config['auth'])?$config['auth']:'auth_';

$this->depr              = isset($config['depr'])?$config['depr']:'-';

}

//

public function init(){

$this->user_id       = 0;

$this->username      = $this->guest_name;

$this->ok            = false;

if(!$this->check_session()){

$this->check_cookie();

}

return $this->ok;

}

//验证SESSION

private function check_session(){

if(!empty($_SESSION[$this->pre_username])&&!empty($_SESSION[$this->pre_password])){

return $this->check($_SESSION[$this->pre_username],$_SESSION[$this->pre_password]);

} else {

return false;

}

}

//验证COOKIE

private function check_cookie(){

if(!empty($_COOKIE[$this->pre_username])&&!empty($_COOKIE[$this->pre_password])){

return $this->check($_COOKIE[$this->pre_username],$_COOKIE[$this->pre_password]);

} else {

return false;

}

}

//登陆

public function login($username,$password){

$sql    = "select ".$this->select_uid." from ".$this->select_table." where ".$this->select_usersname."='$username' and ".$this->select_password."='$password'";

$result = mysql_query($sql);

$rows   = mysql_num_rows($sql);

if($rows==1){

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

$this->username  = $username;

$this->ok        = true;

$username   = $username.$this->depr.$this->get_ip();

$user_name  = $this->encrypt($username,'E',$this->salt);

$_SESSION[$this->pre_username]=$user_name;

$_SESSION[$this->pre_password]=md5(md5($password,$this->salt));

setcookie($this->pre_username,$user_name,time()+$this->cookie_time,$this->cookie_where,$this->cookie_domain,$this->cookie_secure);

setcookie($this->pre_password,md5(md5($password,$this->salt)),time()+$this->cookie_time,$this->cookie_where,$this->cookie_domain,$this->cookie_secure);

return true;

}

return false;

}

//验证

private function check($username,$password){

$user_name  = $this->encrypt($username,'D',$this->salt);

$name       = explode($this->depr, $user_name);

$username   = $name[0];

$ip         = isset($name[1]) ? $name[1] : NULL;

if($ip !== $this->get_ip()) return false;

static $vars = array();

if(!empty($vars)&&is_array($vars)&&isset($vars[$username.$password])){

$this->user_id   = $vars['user_id'];

$this->username  = $vars['username'];

$this->ok        = $vars['ok'];

return true;

}

$sql    = "select ".$this->select_uid.",".$this->select_password." from ".$this->select_table." where ".$this->select_usersname."='$username'";

$query  = mysql_query($sql);

$result = mysql_fetch_array($query);

$row    = mysql_num_rows($sql);

if($row == 1){

$db_password=$result[$this->select_password];

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

$this->user_id   = $vars['user_id']  = $result[$this->select_uid];

$this->username  = $vars['username'] = $username;

$this->ok        = $vars['ok']       = true;

$vars[$username.$password]          = md5($username.$password);

return true;

}

}

return false;

}

//退出

public function logout(){

$this->user_id       = 0;

$this->username      = $this->guest_name;

$this->ok            = false;

$_SESSION[$this->pre_username]="";

$_SESSION[$this->pre_password]="";

setcookie($this->pre_username,"",time()-$this->cookie_time,$this->cookie_where,$this->cookie_domain,$this->cookie_secure);

setcookie($this->pre_password,"",time()-$this->cookie_time,$this->cookie_where,$this->cookie_domain,$this->cookie_secure);

}

//加密

public function encrypt($string,$operation,$key='') {

$key=md5($key);

$key_length=strlen($key);

$string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string;

$string_length=strlen($string);

$rndkey=$box=array();

$result='';

for($i=0;$i<=255;$i++)

{

$rndkey[$i]=ord($key[$i%$key_length]);

$box[$i]=$i;

}

for($j=$i=0;$i<256;$i++)

{

$j=($j+$box[$i]+$rndkey[$i])%256;

$tmp=$box[$i];

$box[$i]=$box[$j];

$box[$j]=$tmp;

}

for($a=$j=$i=0;$i

{

$a=($a+1)%256;

$j=($j+$box[$a])%256;

$tmp=$box[$a];

$box[$a]=$box[$j];

$box[$j]=$tmp;

$result.=chr(ord($string[$i])^($box[($box[$a]+$box[$j])%256]));

}

if($operation=='D')

{

if(substr($result,0,8)==substr(md5(substr($result,8).$key),0,8))

{

return substr($result,8);

}

else

{

return'';

}

}

else

{

return str_replace('=','',base64_encode($result));

}

}

public function get_ip() {

return $_SERVER['REMOTE_ADDR'];

}

}

?>

以上就是本文的全部内容了,希望大家能够喜欢。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值