php用户登陆类
来源:互联网 发布:网络咨询医生工资 编辑:程序博客网 时间:2024/05/22 07:43
<?php
/*
* 描述:PHP用于登录的类,基于MySQL
*/
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”;
}
}
?>
- php用户登陆类
- php用户登陆
- php用户验证登陆代码
- PHP登陆并且验证用户
- php 如何把别的登陆用户注销
- PHP获取当前登陆用户IP
- php登陆人人网和用户主页
- PHP获取当前登陆用户IP
- php使用curl模拟用户登陆
- php保存cookie用户登陆的问题
- PHP会话(Session)实现用户登陆功能
- PHP会话(Session)实现用户登陆功能
- PHP会话(Session)实现用户登陆功能
- PHP 实现用户注册及登陆
- PHP会话(Session)实现用户登陆功能
- PHP 验证登陆类
- php同个用户同时只能登陆一个, 后登陆者踢掉前登陆者
- 解析WordPress中控制用户登陆和判断用户登陆的PHP函数
- 在MySql 中使用存储过程分割字符串
- T-Sql学习(14) - 事务处理
- SQL server服务器大内存配置
- js例子
- PHPMailer类-php发送邮件好帮手
- php用户登陆类
- 关于在vs2003中打不开解决方案的解决方法
- SM13 使用方法
- FLEX教程
- SQL中的临时表和表变量
- Find all prime factors of a number
- 几种流行的AJAX框架jQuery,Mootools,Dojo,Ext JS的对比
- 钩子技术介绍(1)
- C#中使用指针