PHP用户注册与登录前言网站用户注册与登录是很常用的一个功能,本节教材就以此来演示一下PHP中如何开发用户注册与登录模块。本节需要用到的重点PHP基础知识:PHP中预定义$_POST和$_GET全局变量来接受用户表单和URL参数信息,关于PHP表单更多信息参见《PHP表单》。PHP正则表达式用于判断用户的输入是否符合要求,关于正则表达式更多信息参见《PHP正则表达式》。用户登录检测通过后以session来保持用户的登录信息,关于session更多信息参见《PHPSession》或者《PHPCookie》。需求分析主要功能分为用户注册、用户登录、用户退出、用户中心四个部分。用户注册用户注册主要功能有:1.注册信息表单填写界面javascript脚本初步检测用户输入的注册信息。2.注册处理模块检测注册信息是否符合要求。3.检测用户名是否已存在。4.将注册信息写入数据表,注册成功。用户登录用户登录主要功能有:1.登录表单界面javascript脚本初步检测用户输入的登录信息。2.登录模块将用户输入信息与数据库数据进行核对。3.登录信息正确,则提示登录成功,将用户设置为登录状态(session)。4.登录信息不正确,则提示登录失败,用户可以再次尝试登录。用户退出用户退出主要功能有:1.无条件注销session。用户中心用户退出主要功能有:1.判断用户是否登录,如果没有登录,则转向到登录界面。2.如果登录是登录状态,则读出用户相关信息。数据表设计根据功能需求分析,用于记用户信息的user表需要的字段如下:字段名数据类型说明uidmediumint(8)主键,自动增长usernamechar(15)注册用户名passwordchar(32)MD5加密后的密码emailvarchar(40)用户Emailregdateint(10)用户注册时间戳建表SQL参考如下:CREATETABLE`user`(`uid`mediumint(8)unsignedNOTNULLauto_increment,`username`char(15)NOTNULLdefault'',`password`char(32)NOTNULLdefault'',`email`varchar(40)NOTNULLdefault'',`regdate`int(10)unsignedNOTNULLdefault'0',PRIMARYKEY(`uid`))ENGINE=MyISAMDEFAULTCHARSET=utf8AUTO_INCREMENT=1;页面布局各页面功能如下:reg.html:用户注册信息填写表单页面conn.php:数据库连接包含文件reg.php:用户注册处理程序login.html:用户登录表单页面login.php:用户登录表单页面my.php:用户中心注册页面reg.html负责收集用户填写的注册信息。教程里只列出关键的代码片段,完整的代码附在本节最后。注册表单fieldsetlegend用户注册/legendformname=RegFormmethod=postaction=reg.phponSubmit=returnInputCheck(this)plabelfor=usernameclass=label用户名:/labelinputid=usernamename=usernametype=textclass=input/span(必填,3-15字符长度,支持汉字、字母、数字及_)/spanp/plabelfor=passwordclass=label密码:/labelinputid=passwordname=passwordtype=passwordclass=input/span(必填,不得少于6位)/spanp/plabelfor=repassclass=label重复密码:/labelinputid=repassname=repasstype=passwordclass=input/p/plabelfor=emailclass=label电子邮箱:/labelinputid=emailname=emailtype=textclass=input/span(必填)/spanp/pinputtype=submitname=submitvalue=提交注册class=left//p/form/fieldsetjavascript检测代码scriptlanguage=JavaScript!--functionInputCheck(RegForm){if(RegForm.username.value==){alert(用户名不可为空!);RegForm.username.focus();return(false);}if(RegForm.password.value==){alert(必须设定登录密码!);RegForm.password.focus();return(false);}if(RegForm.repass.value!=RegForm.password.value){alert(两次密码不一致!);RegForm.repass.focus();return(false);}if(RegForm.email.value==){alert(电子邮箱不可为空!);RegForm.email.focus();return(false);}}//--/scriptCSS样式styletype=text/csshtml{font-size:12px;}fieldset{width:520px;margin:0auto;}legend{font-weight:bold;font-size:14px;}label{float:left;width:70px;margin-left:10px;}.left{margin-left:80px;}.input{width:150px;}span{color:#666666;}/style注册表单效果图:数据库连接?php$conn=@mysql_connect(localhost,root,root123);if(!$conn){die(连接数据库失败:.mysql_error());}mysql_select_db(test,$conn);//字符转换,读库mysql_query(setcharacterset'gbk');//写库mysql_query(setnames'gbk');?注册处理reg.php负责处理用户注册信息。注册检测if(!isset($_POST['submit'])){exit('非法访问!');}$username=$_POST['username'];$password=$_POST['password'];$email=$_POST['email'];//注册信息判断if(!preg_match('/^[\w\x80-\xff]{3,15}$/',$username)){exit('错误:用户名不符合规定。ahref=javascript:history.back(-1);返回/a');}if(strlen($password)6){exit('错误:密码长度不符合规定。ahref=javascript:history.back(-1);返回/a');}if(!preg_match('/^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$/',$email)){exit('错误:电子邮箱格式错误。ahref=javascript:history.back(-1);返回/a');}本段代码首先检测是否POST提交访问该页,接下来根据注册要求(用户名3-15字符长度,支持汉字、字母、数字及_;密码不得少于6位)对用户提交的注册信息进行检测。在检测用户名和电子邮箱时采用了正则检测,关于正则表达式更所信息请参看《PHP正则表达式》。数据库交互//包含数据库连接文件include('conn.php');//检测用户名是否已经存在$check_query=mysql_query(selectuidfromuserwhereusername='$username'limit1);if(mysql_fetch_array($check_query)){echo'错误:用户名',$username,'已存在。ahref=javascript:history.back(-1);返回/a';exit;}//写入数据$password=MD5($password);$regdate=time();$sql=INSERTINTOuser(username,password,email,regdate)VALUES('$username','$password','$email',$regdate);if(mysql_query($sql,$conn)){exit('用户注册成功!点击此处ahref=login.html登录/a');}else{echo'抱歉!添加数据失败:',mysql_error(),'br/';echo'点击此处ahref=javascript:history.back(-1);返回/a重试';}登录页面login.html负责收集用户填写的登录信息。fieldsetlegend用户登录/legendformname=LoginFormmethod=postaction=login.phponSubmit=returnInputCheck(this)plabelfor=usernameclass=label用户名:/labelinputid=usernamename=usernametype=textclass=input/p/plabelfor=passwordclass=label密码:/labelinputid=passwordname=passwordtype=passwordclass=input/p/pinputtype=submitname=submitvalue=确定class=left//p/form/fieldsetjavascript检测及CSS样式可参考reg.html,本部分略去,可直接查看最后附录的完整代码。登录处理login.php负责处理用户登录与退出动作。//登录if(!isset($_POST['submit'])){exit('非法访问!');}$username=htmlspecialchars($_POST['username']);$password=MD5($_POST['password']);//包含数据库连接文件include('conn.php');//检测用户名及密码是否正确$check_query=mysql_query(selectuidfromuserwhereusername='$username'andpassword='$password'limit1);if($result=mysql_fetch_array($check_query)){//登录成功$_SESSION['username']=$username;$_SESSION['userid']=$result['uid'];echo$username,'欢迎你!进入ahref=my.php用户中心/abr/';echo'点击此处ahref=login.php?action=logout注销/a登录!br/';exit;}else{exit('登录失败!点击此处ahref=java