用PHP写的MySQL数据库用户认证系统代码


Posted in PHP onMarch 22, 2007

这两天受朋友的托付,要我帮他写一个使用MySQL数据库的用户认证系统。我当然不好推脱的,只得耗费了一晚上的休息时间,写了个很简单的PHP程序。 
用户认证的原理很简单:首先需要用户在页面上填入用户名和密码,当然没注册的用户需要先注册。然后调用数据库搜索是否有相应的用户。如果有就确认,没有则提醒用户先注册。使用PHP来完成这一切很简单,但需要注意的是如果想在以后的页面中都能确认用户身份,使用PHP3我只能想出使用cookie的方法。要想使用session,就只能等待PHP4正式版的发布了! 
第一步是做一个登录的页面,这儿就不多讲了。我只做了个极简单的,大家可以做得漂亮点。 
第二步开始登录后的确认程序的设计。 
login.php:? 

mysql_connect("localhost","user","password")   
/*连接数据库,用户名和密码自行修改*/   
or die("无法连接数据库,请重试");   
mysql_select_db("userinfo")   
or die("无法选择数据库,请重试");   
$today=date("Y-m-d H:i:s");   
$query="   
select id   
from usertbl   
where name=$name and password=$password   
/*从数据库中搜索和登录用户相应的资料*/   
";   
$result=mysql_query($query);   
$numrows=mysql_num_rows($result);   
if($numrows==0){   
/*验证是否能找出相同资料的用户,不能则未注册*/   
echo 非法用户  echo 请注册先  
echo 重试  
}   
else{   
$row=mysql_fetch_array($result);   
$id=$row[0];   
$query="   
update usertbl   
set lastlogin=$today   
where id=$id";   
$result=mysql_query($query);   
SetCookie("usercookie", "欢迎你,$name");  
 /*这里使用了cookie,以方便之后的页面认证。  
但我未开发完这一块。希望有兴趣的朋友指正*/   
echo 登录成功  
echo 请进!  
}   
?> 

第三步当然是做好注册的页面,也不多讲了。 
第四步是注册后的身份确认和输入数据库。 
register.php: 
mysql_connect("localhost","user","password") /*请修改用户名和密码*/   
or die("无法连接数据库,请重试");   
mysql_select_db("userinfo")   
or die("无法选择数据库,请重试");   
$query="select id from usertbl where name=$name\";  
 /*从数据库中搜索相同名字的用户资料*/   
$result=mysql_query($query);   
$numrows=mysql_num_rows($result);   
if($numrows!=0) /*找到了当然就是有人先注册了相同的名字*/   
{echo 已有人注册此名,请重新选择名字!;}   
else   
{$query="insert into usertbl values(0,$name,$password,\)";  
 /*找不到相同的就输入新的用户资料*/   
mysql_query($query);   
echo 注册成功;   
echo 请登录!;}   
?> 
下一步是cookie的使用,我原打算使用cookie来使每一页都能识别用户身份,但由于别的页面还没做好,不知道需要用到哪些资料。于是就只有一个很简单的使用,这里用到了php的引用: 
if(!$usercookie)   
{header("非法用户");   
}   
?>   
welcome.php:   
require("cookie.php"); /*调用cookie.php*/   
?>   
echo $usercookie;   
?> 
到这儿便完成了一个很简单的用户认证系统,当然如果你要使用它还得建好数据库。下面是我的数据库表的结构,库的名字是userinfo。 
create table usertbl   
(   
ID int auto_increment primary key,   
Name varchar(30),   
Password varchar(20),   
Lastlogin varchar(20)   
); 
PHP 相关文章推荐
使用sockets:从新闻组中获取文章(二)
Oct 09 PHP
发挥语言的威力--融合PHP与ASP
Oct 09 PHP
比较discuz和ecshop的截取字符串函数php版
Sep 03 PHP
php实现的Curl封装类Curl.class.php用法实例分析
Sep 25 PHP
学习php设计模式 php实现建造者模式
Dec 07 PHP
php简单获取复选框值的方法
May 11 PHP
PHP读取大文件的几种方法介绍
Oct 27 PHP
支付宝支付开发――当面付条码支付和扫码支付实例
Nov 04 PHP
PHP使用pdo实现事务处理操作示例
Sep 05 PHP
laravel 解决groupBy时出现的错误 isn't in Group By问题
Oct 17 PHP
TP3.2框架分页相关实现方法分析
Jun 03 PHP
PHP实现简易用户登录系统
Jul 10 PHP
人尽可用的Windows技巧小贴士之下篇
Mar 22 #PHP
加速XP搜索功能堪比vista
Mar 22 #PHP
dedecms中常见问题修改方法总结
Mar 21 #PHP
dedecms后台验证码总提示错误的解决方法
Mar 21 #PHP
dedecms中显示数字验证码的修改方法
Mar 21 #PHP
PHP的分页功能
Mar 21 #PHP
完美解决dedecms中的[html][/html]和[code][/code]问题
Mar 20 #PHP
You might like
用PHP函数解决SQL injection
2006/12/09 PHP
基于PHP Socket配置以及实例的详细介绍
2013/06/13 PHP
php实现递归的三种基本方式
2020/07/04 PHP
thinkPHP中_initialize方法实例分析
2016/12/05 PHP
yii2.0整合阿里云oss的示例代码
2017/09/19 PHP
php swoft框架实例用法
2020/12/22 PHP
jquery 可排列的表实现代码
2009/11/13 Javascript
IE 上下滚动展示模仿Marquee机制
2009/12/20 Javascript
JS文本框追加多个下拉框的值的简单实例
2013/07/12 Javascript
深入分析escape()、encodeURI()、encodeURIComponent()的区别及示例
2014/08/04 Javascript
Js为表单动态添加节点内容的方法
2015/02/10 Javascript
javascript中基本类型和引用类型的区别分析
2015/05/12 Javascript
js表单提交和submit提交的区别实例分析
2015/12/10 Javascript
Angular2 (RC5) 路由与导航详解
2016/09/21 Javascript
Javascript 实现计算器时间功能详解及实例(二)
2017/01/08 Javascript
JS使用ActiveXObject实现用户提交表单时屏蔽敏感词功能
2017/06/20 Javascript
简单实现js放大镜效果
2017/07/24 Javascript
js实现方块上下左右移动效果
2017/08/17 Javascript
JS中使用textPath实现线条上的文字
2017/12/25 Javascript
AngularJS双向数据绑定原理之$watch、$apply和$digest的应用
2018/01/30 Javascript
JavaScript常用数学函数用法示例
2018/05/14 Javascript
JavaScript async/await原理及实例解析
2020/12/02 Javascript
Python描述器descriptor详解
2015/02/03 Python
详解在Python程序中自定义异常的方法
2015/10/16 Python
利用CSS3把图片变成灰色模式的实例代码
2016/09/06 HTML / CSS
丹尼尔惠灵顿手表天猫官方旗舰店:Daniel Wellington
2017/08/25 全球购物
荷兰网上买鞋:MooieSchoenen.nl
2017/09/12 全球购物
德国自行车商店:Tretwerk
2019/06/21 全球购物
户外用品商店创业计划书
2014/01/29 职场文书
公司门卫管理制度
2014/02/01 职场文书
行政办公室岗位职责
2014/03/18 职场文书
写求职信要注意什么问题
2014/04/12 职场文书
2014年德育工作总结
2014/11/20 职场文书
利用javaScript处理常用事件详解
2021/04/14 Javascript
Mysql 如何合理地统计一个数据库里的所有表的数据量
2022/04/18 MySQL
Python中的 enumerate和zip详情
2022/05/30 Python