欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php的一個(gè)登錄的類 [推薦]

 更新時(shí)間:2007年03月16日 00:00:00   作者:  
PHP代碼:
<?
/*
* 名稱:CnkknD PHP Login Class
* 描述:PHP用于登錄的類,基于MySQL
* 作者:Daniel King,cnkknd@163.com
* 日期:2003/8/25
*/

class Login
{
var $username; //用戶名
var $userpass; //密碼
var $userid; //用戶id
var $userlevel; //用戶級(jí)別

var $authtable="account"; //驗(yàn)證用數(shù)據(jù)表

var $usecookie=true; //使用cookie保存sessionid
var $cookiepath='/'; //cookie路徑
var $cookietime=108000; //cookie有效時(shí)間

var $err_mysql="mysql error"; //mysql出錯(cuò)提示
var $err_username="username invalid"; //用戶名無(wú)效提示
var $err_user="user invalid"; //用戶無(wú)效提示(被封禁)
var $err_password="password error"; //密碼錯(cuò)誤提示

var $err; //出錯(cuò)提示

var $errorreport=false; //顯示錯(cuò)誤

function Login($dbserv,$dbport,$dbuser,$dbpass,$dbname) //構(gòu)造函數(shù),連接數(shù)據(jù)庫(kù)
{
if(@mysql_pconnect($dbserv.":".$dbport,$dbuser,$dbpass))
{
mysql_select_db($dbname);
}
else
{
$this->errReport($this->err_mysql);
$this->err=$this->err_mysql;
}
}

function isLoggedin() //判斷是否登錄
{
if(isset($_COOKIE['sid'])) //如果cookie中保存有sid
{
session_id($_COOKIE['sid']);
session_start();
$this->username=$_SESSION['username'];
$this->userid=$_SESSION['userid'];
$this->userlevel=$_SESSION['userlevel'];
return true;
}
else //如果cookie中未保存sid,則直接檢查session
{
session_start();
if(isset($_SESSION['username']))
return true;
}
return false;
}

function userAuth($username,$userpass) //用戶認(rèn)證
{
$this->username=$username;
$this->userpass=$userpass;
$query="select * from `".$this->authtable."` where `username`='$username';";
$result=mysql_query($query);
if(mysql_num_rows($result)!=0) //找到此用戶
{
$row=mysql_fetch_array($result);
if($row['bannd']==1) //此用戶被封禁
{
$this->errReport($this->err_user);
$this->err=$this->err_user;
return false;
}
elseif(md5($userpass)==$row['userpass']) //密碼匹配
{
$this->userid=$row['id'];
$this->userlevel=$row['userlevel'];
return true;
}
else //密碼不匹配
{
$this->errReport($this->err_password);
$this->err=$this->err_password;
return false;
}
}
else //沒(méi)有找到此用戶
{
$this->errReport($this->err_username);
$this->err=$this->err_username;
return false;
}
}

function setSession() //置session
{
$sid=uniqid('sid'); //生成sid
session_id($sid);
session_start();
$_SESSION['username']=$this->username; //給session變量賦值
$_SESSION['userid']=$this->userid; //..
$_SESSION['userlevel']=$this->userlevel; //..
if($this->use_cookie) //如果使用cookie保存sid
{
if(!setcookie('sid',$sid,time()+$this->cookietime,$this->cookiepath))
$this->errReport("set cookie failed");
}
else
setcookie('sid','',time()-3600); //清除cookie中的sid
}

function userLogout() //用戶注銷(xiāo)
{
session_start();
unset($_SESSION['username']); //清除session中的username
if(setcookie('sid','',time()-3600))
//清除cookie中的sid
return true;
else 
return false;
}

function errReport($str) //報(bào)錯(cuò)
{
if($this->error_report)
echo "ERROR: $str";
}
}
?> 

mysql中表的結(jié)構(gòu)


代碼:
CREATE TABLE `account` (
  `id` bigint(20) NOT NULL auto_increment,
  `username` varchar(255) NOT NULL default '',
  `userpass` varchar(255) NOT NULL default '',
  `banned` tinyint(1) NOT NULL default '0',
  `userlevel` tinyint(4) NOT NULL default '0',
  PRIMARY KEY  (`id`)



使用一例


PHP代碼:
<?
include "../myclasses/Login.php";
$dbserv="localhost";
$dbport="3306";
$dbuser="root";
$dbpass="123456";
$dbname="test";

$login=new Login($dbserv,$dbport,$dbuser,$dbpass,$dbname);
$login->error_report=true;
$login->cookietime=3600*24*30;
if($login->isLoggedin())
{
echo $login->username." has aready logged in";
}
elseif($login->userAuth("danielking","1234"))
{
echo "login successfully";
$login->setSession();
}

echo "<p>...</p>";

/*
if($login->userLogout())
echo "logged out";
else
echo "logout failed";
*/
?>  

 

相關(guān)文章

  • PHP 7.4中使用預(yù)加載的方法詳解

    PHP 7.4中使用預(yù)加載的方法詳解

    這篇文章主要給大家介紹了關(guān)于PHP 7.4中使用預(yù)加載的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用PHP 7.4具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • php INI配置文件的解析實(shí)現(xiàn)分析

    php INI配置文件的解析實(shí)現(xiàn)分析

    我不知道怎么說(shuō)才好,因?yàn)槲以谧xINI文件的時(shí)候,往往都是用現(xiàn)成的函數(shù):parse_ini_file或者是parse_ini_string,但怎么寫(xiě)入,就是另外的方法了(自己實(shí)現(xiàn)。。。。)
    2011-01-01
  • PHP獲取系統(tǒng)毫秒數(shù)時(shí)間方法

    PHP獲取系統(tǒng)毫秒數(shù)時(shí)間方法

    這篇文章主要介紹了PHP獲取系統(tǒng)毫秒數(shù)時(shí)間方法,php中獲取時(shí)間方法是date(),在php中獲取時(shí)間戳方法有time()、strtotime(),文章通告主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • PHP中余數(shù)、取余的妙用

    PHP中余數(shù)、取余的妙用

    這篇文章主要介紹了PHP中余數(shù)、取余的妙用,這個(gè)是在WEB開(kāi)發(fā)中一個(gè)經(jīng)常使用的小技巧,不管是在表格、ul、li或者是換行等HTML處理中,需要隔幾行換行,隔幾行加入ul或li的結(jié)束標(biāo)記等時(shí)候,特別的有用,需要的朋友可以參考下
    2015-06-06
  • PHP源代碼數(shù)組統(tǒng)計(jì)count分析

    PHP源代碼數(shù)組統(tǒng)計(jì)count分析

    偶然在百度知道中看到有個(gè)同學(xué)問(wèn)起count及strlen的效率問(wèn)題,好吧這個(gè)問(wèn)題我當(dāng)初沒(méi)理解透徹,認(rèn)為其不屬兩個(gè)不一樣的東西不可比較,后來(lái)看了樓主的回復(fù)才反應(yīng)過(guò)來(lái),所以自己也去找了下源碼查看下。現(xiàn)在總結(jié)下查看到的結(jié)果并記錄之。
    2011-08-08
  • 探討php define()函數(shù)及defined()函數(shù)使用詳解

    探討php define()函數(shù)及defined()函數(shù)使用詳解

    本篇文章是對(duì)php中define()函數(shù)及defined()函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 7個(gè)超級(jí)實(shí)用的PHP代碼片段

    7個(gè)超級(jí)實(shí)用的PHP代碼片段

    關(guān)鍵的時(shí)候能拿得出關(guān)鍵代碼才是好的程序員。這篇文章里芒果小站收集了一些諸如此類的關(guān)鍵代碼,有用于編程。
    2011-07-07
  • php xml常用函數(shù)的集合(比較詳細(xì))

    php xml常用函數(shù)的集合(比較詳細(xì))

    本篇文章是對(duì)php中xml常用函數(shù)進(jìn)行了詳細(xì)的總結(jié)與介紹,需要的朋友參考下
    2013-06-06
  • php處理json時(shí)中文問(wèn)題的解決方法

    php處理json時(shí)中文問(wèn)題的解決方法

    最近在項(xiàng)目里面用到j(luò)son操作,之前測(cè)試都是很正常的,不過(guò)今天在把對(duì)象轉(zhuǎn)換成json的時(shí)候,其中有個(gè)中文屬性變成了null.
    2011-04-04
  • PHP使用Redis實(shí)現(xiàn)防止大并發(fā)下二次寫(xiě)入的方法

    PHP使用Redis實(shí)現(xiàn)防止大并發(fā)下二次寫(xiě)入的方法

    這篇文章主要介紹了PHP使用Redis實(shí)現(xiàn)防止大并發(fā)下二次寫(xiě)入的方法,結(jié)合實(shí)例形式分析了php使用鎖機(jī)制實(shí)現(xiàn)并發(fā)讀寫(xiě)redis情況下的讀寫(xiě)錯(cuò)誤,需要的朋友可以參考下
    2017-10-10

最新評(píng)論