用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 相关文章推荐
用PHP ob_start()控制浏览器cache、生成html实现代码
Feb 16 PHP
php curl常见错误:SSL错误、bool(false)
Dec 28 PHP
修改PHP的memory_limit限制的方法分享
Feb 21 PHP
php中explode与split的区别介绍
Oct 03 PHP
教你如何使用php session
Oct 28 PHP
php检测useragent版本示例
Mar 24 PHP
php版微信小店调用api示例代码
Nov 12 PHP
php获取给定日期相差天数的方法分析
Feb 20 PHP
PHP实现活动人选抽奖功能
Apr 19 PHP
php处理抢购类功能的高并发请求
Feb 08 PHP
PHP实现的支付宝支付功能示例
Mar 26 PHP
如何在PHP中使用AES加密算法加密数据
Jun 24 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
使用 MySQL Date/Time 类型
2008/03/26 PHP
强烈声明: 不要使用(include/require)_once
2013/06/06 PHP
ThinkPHP提示错误Fatal error: Allowed memory size的解决方法
2015/02/12 PHP
PHP创建/删除/复制文件夹、文件
2016/05/03 PHP
php基于websocket搭建简易聊天室实践
2016/10/24 PHP
详解在YII2框架中使用UEditor编辑器发布文章
2018/11/02 PHP
yii框架结合charjs统计上一年与当前年数据的方法示例
2020/04/04 PHP
删除重复数据的算法
2006/11/23 Javascript
JavaScript的变量作用域深入理解
2009/10/25 Javascript
jquery 查找iframe父级页面元素的实现代码
2011/08/28 Javascript
基于jQuery的倒计时实现代码
2012/05/30 Javascript
重写javascript中window.confirm的行为
2012/10/21 Javascript
基于JQuery实现的图片自动进行缩放和裁剪处理
2014/01/31 Javascript
jQuery获取样式中颜色值的方法
2015/01/29 Javascript
js实现iframe自动自适应高度的方法
2015/02/17 Javascript
JavaScript中的Math.sin()方法使用详解
2015/06/15 Javascript
jquery判断输入密码两次是否相等
2020/04/22 Javascript
JavaScript中instanceof运算符的使用示例
2016/06/08 Javascript
JavaScript自定义函数实现查找两个字符串最长公共子串的方法
2016/11/24 Javascript
JS前向后瞻正则表达式定义与用法示例
2016/12/27 Javascript
Vuex和前端缓存的整合策略详解
2017/05/09 Javascript
js 公式编辑器 - 自定义匹配规则 - 带提示下拉框 - 动态获取光标像素坐标
2018/01/04 Javascript
Bootstrap Table中的多选框删除功能
2018/07/15 Javascript
angular2/ionic2 实现搜索结果中的搜索关键字高亮的示例
2018/08/17 Javascript
js仿360开机效果
2019/12/26 Javascript
react ant Design手动设置表单的值操作
2020/10/31 Javascript
[54:10]完美世界DOTA2联赛PWL S2 Magma vs FTD 第二场 11.29
2020/12/03 DOTA
wxPython 入门教程
2008/10/07 Python
对Python 简单串口收发GUI界面的实例详解
2019/06/12 Python
Python实现图片批量加入水印代码实例
2019/11/30 Python
python 使用事件对象asyncio.Event来同步协程的操作
2020/05/04 Python
如何在Canvas上的图形/图像绑定事件监听的实现
2020/09/16 HTML / CSS
Tessabit日本:集世界奢侈品和设计师品牌的意大利精品买手店
2020/01/07 全球购物
捷克母婴用品购物网站:Feedo.cz
2020/12/28 全球购物
4s店总经理岗位职责
2013/12/31 职场文书
win10频率超出范围怎么办?win10老显示超出工作频率范围的解决方法
2022/07/07 数码科技