国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

PHP 驗證登陸類

瀏覽:6日期:2022-09-13 09:53:04

用法

/* * 例子 * * $Auth=new Auth(); * $Auth->login('123@123.com','123'); * $Auth->logout(); * echo $r->init(); ***/

<?php

/* * * @ID: 驗證登陸類 * * @class: Auth.class.php * * @auther: 欣兒 * * @time: 2015/03/12 * * @web: http://my.oschina.net/xinger ***/ classAuth { //外部設置 //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; publicfunction__construct($config=array()){$this->set($config); $this->pre_username=sha1(md5($this->pre.’username’));$this->pre_password=sha1(md5($this->pre.’password’)); } publicfunctionset($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’]:’-’; } // publicfunctioninit(){$this->user_id = 0;$this->username =$this->guest_name;$this->ok = false; if(!$this->check_session()){ $this->check_cookie();} return$this->ok; } //驗證SESSION privatefunctioncheck_session(){if(!empty($_SESSION[$this->pre_username])&&!empty($_SESSION[$this->pre_password])){ return$this->check($_SESSION[$this->pre_username],$_SESSION[$this->pre_password]);}else{ returnfalse;} } //驗證COOKIE privatefunctioncheck_cookie(){if(!empty($_COOKIE[$this->pre_username])&&!empty($_COOKIE[$this->pre_password])){ return$this->check($_COOKIE[$this->pre_username],$_COOKIE[$this->pre_password]);}else{ returnfalse;} } //登陸 publicfunctionlogin($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); returntrue;}returnfalse; } //驗證 privatefunctioncheck($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())returnfalse; 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’]; returntrue;} $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);returntrue; }}returnfalse; } //退出 publicfunctionlogout(){$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); } //加密 publicfunctionencrypt($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<$string_length;$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)) {returnsubstr($result,8); } else {return’’; }}else{ returnstr_replace(’=’,’’,base64_encode($result));} } publicfunctionget_ip() {return$_SERVER[’REMOTE_ADDR’]; }}?> * 例子 * * $Auth=new Auth(); * $Auth->login('123@123.com','123'); * $Auth->logout(); * echo $r->init(); ***/
標簽: PHP
相關文章:
主站蜘蛛池模板: 永丰县| 平昌县| 巫山县| 涡阳县| 鸡西市| 昆山市| 临沧市| 临漳县| 历史| 忻城县| 于田县| 肥城市| 金平| 峡江县| 延津县| 蓝田县| 高碑店市| 南江县| 通渭县| 庆城县| 通榆县| 呼玛县| 抚州市| 克什克腾旗| 库尔勒市| 德令哈市| 雷山县| 桑日县| 定陶县| 张北县| 明溪县| 清原| 巩义市| 凉山| 白银市| 霍林郭勒市| 佛冈县| 通海县| 清镇市| 万山特区| 潮安县|