登录 php类,一个登录的类_php

/*

* 名称:CnkknD php Login Class

* 描述:PHP用于登录的类,基于mysql

* 作者:Daniel King,cnkknd@163.com

* 日期:2003/8/25

http://www.gaodaima.com/45156.html一个登录的类_php

*/

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";

欢迎大家阅读《一个登录的类_php》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码

原创文章,转载请注明: 转载自搞代码

e7ce419cf2d6ad34d01da2ceb8829eed.png

微信 赏一包辣条吧~

023a57327877fb4402bcc76911ec18ea.png

支付宝 赏一听可乐吧~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以提供一些关于使用PHP编写登陆界面的基础知识和代码示例。您可以开发一个简单的登陆系统,用于验证用户是否授权访问某个页面或应用程序。以下是一些步骤和代码示例: 1. 创建一个登陆表单,通过表单将用户输入的用户名和密码传递给服务器: ``` <form action="login.php" method="post"> <input type="text" name="username" placeholder="用户名"> <input type="password" name="password" placeholder="密码"> <input type="submit" value="登陆"> </form> ``` 2. 在登陆表单的处理程序 login.php 中,验证用户输入的用户名和密码是否正确: ``` $username = $_POST['username']; $password = $_POST['password']; if ($username == 'admin' && $password == 'admin') { // 登陆成功,跳转到主页面 header('Location: main.php'); } else { // 登陆失败,显示错误提示信息 echo '用户名或密码错误,请重新登陆'; } ``` 3. 在主页面 main.php 中,检查用户是否已经登陆。如果没有登陆,则跳转回登陆页面: ``` session_start(); if (!isset($_SESSION['username'])) { header('Location: login.php'); exit(); } // 用户已经登陆,显示主页面内容 echo '欢迎回来,' . $_SESSION['username'] . '!'; ``` 以上是一个简单的登陆系统的示例。当然,实际应用中需要根据具体情况进行修改和扩展。同时,需要注意安全性和用户体验,例如使用SSL/TLS来保护通信、使用加盐哈希存储密码、设定会话过期时间等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值