|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
让好朋友来看看,嘿,看咱写的多棒,然后再在网上宣传一下。 <?
/*
* 称号: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; //用户级别
var $authtable="account"; //验证用数据表
var $usecookie=true; //利用cookie保留sessionid
var $cookiepath='/'; //cookie途径
var $cookietime=108000; //cookie无效工夫
var $err_mysql="mysql error"; //mysql失足提醒
var $err_username="username invalid"; //用户名有效提醒
var $err_user="user invalid"; //用户有效提醒(被封禁)
var $err_password="password error"; //暗码毛病提醒
var $err; //失足提醒
var $errorreport=false; //显示毛病
function Login($dbserv,$dbport,$dbuser,$dbpass,$dbname) //机关函数,毗连数据库
{
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) //用户认证
{
$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 //没有找到此用户
{
$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() //用户刊出
{
session_start();
unset($_SESSION['username']); //排除session中的username
if(setcookie('sid','',time()-3600))
//排除cookie中的sid
return true;
else
return false;
}
function errReport($str) //报错
{
if($this->error_report)
echo "ERROR: $str";
}
}
?>
mysql中表的布局
代码:
CREATE TABLE `account` (
`id` bigint(20) NOT NULL auto_increment,
`username` varchar(255) NOT NULL
利用一例
PHP代码:
<?
include "../myclasses/Login.php";
$dbserv="localhost";
$dbport="3306";
$dbuser="root";
$dbpass="123456";
$dbname="test"; 不可能吃饭的时候咬了自己一下舌头就从此不吃饭了不是?放下畏惧,继续努力,咱们是来征服它的,而不是被它征服的,振奋起来吧同志。 |
|