时间:2021-05-26
PHP代码:
<?
/*
*名称:CnkknDPHPLoginClass
*描述:PHP用于登录的类,基于MySQL
*作者:DanielKing,cnkknd@163.com
*日期:2003/8/25
*/
classLogin
{
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="mysqlerror";//mysql出错提示
var$err_username="usernameinvalid";//用户名无效提示
var$err_user="userinvalid";//用户无效提示(被封禁)
var$err_password="passworderror";//密码错误提示
var$err;//出错提示
var$errorreport=false;//显示错误
functionLogin($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;
}
}
functionisLoggedin()//判断是否登录
{
if(isset($_COOKIE['sid']))//如果cookie中保存有sid
{
session_id($_COOKIE['sid']);
session_start();
$this->username=$_SESSION['username'];
$this->userid=$_SESSION['userid'];
$this->userlevel=$_SESSION['userlevel'];
returntrue;
}
else//如果cookie中未保存sid,则直接检查session
{
session_start();
if(isset($_SESSION['username']))
returntrue;
}
returnfalse;
}
functionuserAuth($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;
returnfalse;
}
elseif(md5($userpass)==$row['userpass'])//密码匹配
{
$this->userid=$row['id'];
$this->userlevel=$row['userlevel'];
returntrue;
}
else//密码不匹配
{
$this->errReport($this->err_password);
$this->err=$this->err_password;
returnfalse;
}
}
else//没有找到此用户
{
$this->errReport($this->err_username);
$this->err=$this->err_username;
returnfalse;
}
}
functionsetSession()//置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("setcookiefailed");
}
else
setcookie('sid','',time()-3600);//清除cookie中的sid
}
functionuserLogout()//用户注销
{
session_start();
unset($_SESSION['username']);//清除session中的username
if(setcookie('sid','',time()-3600))
//清除cookie中的sid
returntrue;
else
returnfalse;
}
functionerrReport($str)//报错
{
if($this->error_report)
echo"ERROR:$str";
}
}
?>
mysql中表的结构
代码:
CREATETABLE`account`(
`id`bigint(20)NOTNULLauto_increment,
`username`varchar(255)NOTNULLdefault'',
`userpass`varchar(255)NOTNULLdefault'',
`banned`tinyint(1)NOTNULLdefault'0',
`userlevel`tinyint(4)NOTNULLdefault'0',
PRIMARYKEY(`id`)
)
使用一例
PHP代码:
<?
include"../myclasses/Login.php";
$dbserv="localhost";
$dbport="3306";
$dbuser="root";
$dbpass="123456";
$dbname="test";
$login=newLogin($dbserv,$dbport,$dbuser,$dbpass,$dbname);
$login->error_report=true;
$login->cookietime=3600*24*30;
if($login->isLoggedin())
{
echo$login->username."hasareadyloggedin";
}
elseif($login->userAuth("danielking","1234"))
{
echo"loginsuccessfully";
$login->setSession();
}
echo"<p>...</p>";
?>
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
当你尝试使用一个未定义的类时,PHP会报告一个致命错误.解决方法就是添加一个类,可以用include包含一个文件.毕竟你知道要用到哪个类.但是,PHP提供了类的
PHP接口PHP类是单继承,也就是不支持多继承,当一个类需要多个类的功能时,继承就无能为力了,为此PHP引入了类的接口技术。如果一个抽象类里面的所有方法都是抽象
一、创建项目作为演示,我们在www根目录创建项目grabimg,创建一个类GrabImage.php和一个index.php。二、编写类代码我们定义一个和文件名
这个PHP的数据库连接类,应该算是最简单的一个连接类了,也是最好明白的一个连接类.作为开始PHP面向编程之旅的一个开始吧.我看了很多网上流传的MYSQL数据库连
用PHP写一个验证码类,并进行封装。类名:validationcode.class.php代码如下:复制代码代码如下: