用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 相关文章推荐
一个简洁的多级别论坛
Oct 09 PHP
PHP 巧用数组降低程序的时间复杂度
Jan 01 PHP
php cache类代码(php数据缓存类)
Apr 15 PHP
PHP 编写大型网站问题集
May 07 PHP
PHP 读取大文件的X行到Y行内容的实现代码
Jun 24 PHP
php中通过curl检测页面是否被百度收录
Sep 27 PHP
php使用imagick模块实现图片缩放、裁剪、压缩示例
Apr 17 PHP
深入浅出讲解:php的socket通信原理
Dec 03 PHP
Laravel使用支付宝进行支付的示例代码
Aug 16 PHP
PHP检查URL包含特定字符串实例方法
Feb 11 PHP
php常用日期时间函数实例小结
Jul 04 PHP
Laravel5.5 手动分页和自定义分页样式的简单实现
Oct 15 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
自动跳转中英文页面
2006/10/09 PHP
php利用iframe实现无刷新文件上传功能的代码
2011/09/29 PHP
PHP strip_tags()去除HTML、XML以及PHP的标签介绍
2014/02/18 PHP
PHP实现Google plus的好友拖拽分组效果
2016/10/21 PHP
对laravel的session获取与存取方法详解
2019/10/08 PHP
PHP高并发和大流量解决方案整理
2021/03/09 PHP
js静态作用域的功能。
2006/12/25 Javascript
javascript 字符串连接的性能问题(多浏览器)
2008/11/18 Javascript
jQuery的三种$()
2009/12/30 Javascript
jquery Tab效果和动态加载的简单实例
2013/12/11 Javascript
JS的参数传递示例介绍
2014/02/08 Javascript
js图片实时加载提供网页打开速度
2014/09/11 Javascript
使用不同的方法结合/合并两个JS数组
2014/09/18 Javascript
Javascript中this的用法详解
2014/09/22 Javascript
jQuery实现表格展开与折叠的方法
2015/05/04 Javascript
浅谈javascript中replace()方法
2015/11/10 Javascript
学习JavaScript设计模式之装饰者模式
2016/01/19 Javascript
使用JavaScript根据图片获取条形码的方法
2017/07/04 Javascript
前端把html表格生成为excel表格的实例
2017/09/19 Javascript
vue移动端路由切换实例分析
2018/05/14 Javascript
VUE解决微信签名及SPA微信invalid signature问题(完美处理)
2019/03/29 Javascript
vue2.0项目集成Cesium的实现方法
2019/07/30 Javascript
微信小程序前端promise封装代码实例
2019/08/24 Javascript
[14:03]2017DOTA2亚洲邀请赛开幕式:12神兵演绎水墨中华
2017/04/01 DOTA
python定时采集摄像头图像上传ftp服务器功能实现
2013/12/23 Python
Python发送form-data请求及拼接form-data内容的方法
2016/03/05 Python
使用Tensorflow将自己的数据分割成batch训练实例
2020/01/20 Python
浅谈Python中的生成器和迭代器
2020/06/19 Python
Top Villas美国:豪华别墅出租和度假屋
2018/07/10 全球购物
Strathberry苏贝瑞中国官网:西班牙高级工匠手工打造
2020/10/19 全球购物
设计模式的基本要素是什么
2014/04/21 面试题
掌上明珠Java程序员面试总结
2016/02/23 面试题
家长对小学生的评语
2014/01/28 职场文书
动员大会主持词
2014/03/20 职场文书
小学模范班主任事迹材料
2014/05/13 职场文书
支部书记四风对照材料
2014/08/28 职场文书