PHP注册与登录【2】用户注册

注册页面

reg.html 负责收集用户填写的注册信息。教程里只列出关键的代码片段,完整的代码附在本节最后。

注册表单

 1 <fieldset>
 2 <legend>用户注册</legend>
 3 <form name="RegForm" method="post" action="reg.php" onSubmit="return InputCheck(this)">
 4 <p>
 5 <label for="username" class="label">用户名:</label>
 6 <input id="username" name="username" type="text" class="input" />
 7 <span>(必填,3-15字符长度,支持汉字、字母、数字及_)</span>
 8 <p/>
 9 <p>
10 <label for="password" class="label">密 码:</label>
11 <input id="password" name="password" type="password" class="input" />
12 <span>(必填,不得少于6位)</span>
13 <p/>
14 <p>
15 <label for="repass" class="label">重复密码:</label>
16 <input id="repass" name="repass" type="password" class="input" />
17 <p/>
18 <p>
19 <label for="email" class="label">电子邮箱:</label>
20 <input id="email" name="email" type="text" class="input" />
21 <span>(必填)</span>
22 <p/>
23 <p>
24 <input type="submit" name="submit" value="  提交注册  " class="left" />
25 </p>
26 </form>
27 </fieldset>

javascript 检测代码

 1 <script language=JavaScript>
 2 <!--
 3 
 4 function InputCheck(RegForm)
 5 {
 6   if (RegForm.username.value == "")
 7   {
 8     alert("用户名不可为空!");
 9     RegForm.username.focus();
10     return (false);
11   }
12   if (RegForm.password.value == "")
13   {
14     alert("必须设定登录密码!");
15     RegForm.password.focus();
16     return (false);
17   }
18   if (RegForm.repass.value != RegForm.password.value)
19   {
20     alert("两次密码不一致!");
21     RegForm.repass.focus();
22     return (false);
23   }
24   if (RegForm.email.value == "")
25   {
26     alert("电子邮箱不可为空!");
27     RegForm.email.focus();
28     return (false);
29   }
30 }
31 
32 //-->
33 </script>

CSS 样式

1 <style type="text/css">
2     html{font-size:12px;}
3     fieldset{width:520px; margin: 0 auto;}
4     legend{font-weight:bold; font-size:14px;}
5     label{float:left; width:70px; margin-left:10px;}
6     .left{margin-left:80px;}
7     .input{width:150px;}
8     span{color: #666666;}
9 </style>

注册表单效果图:

数据库连接

 1 <?php
 2 $conn = @mysql_connect("localhost","root","root123");
 3 if (!$conn){
 4     die("连接数据库失败:" . mysql_error());
 5 }
 6 mysql_select_db("test", $conn);
 7 //字符转换,读库
 8 mysql_query("set character set 'gbk'");
 9 //写库
10 mysql_query("set names 'gbk'");
11 ?>

注册处理

reg.php 负责处理用户注册信息。

注册检测

 1 if(!isset($_POST['submit'])){
 2     exit('非法访问!');
 3 }
 4 $username = $_POST['username'];
 5 $password = $_POST['password'];
 6 $email = $_POST['email'];
 7 //注册信息判断
 8 if(!preg_match('/^[\w\x80-\xff]{3,15}$/', $username)){
 9     exit('错误:用户名不符合规定。<a href="javascript:history.back(-1);">返回</a>');
10 }
11 if(strlen($password) < 6){
12     exit('错误:密码长度不符合规定。<a href="javascript:history.back(-1);">返回</a>');
13 }
14 if(!preg_match('/^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$/', $email)){
15     exit('错误:电子邮箱格式错误。<a href="javascript:history.back(-1);">返回</a>');
16 }

本段代码首先检测是否 POST 提交访问该页,接下来根据注册要求(用户名 3-15 字符长度,支持汉字、字母、数字及_;密码不得少于 6 位)对用户提交的注册信息进行检测。在检测用户名和电子邮箱时采用了正则检测。

数据库交互

 1 //包含数据库连接文件
 2 include('conn.php');
 3 //检测用户名是否已经存在
 4 $check_query = mysql_query("select uid from user where username='$username' limit 1");
 5 if(mysql_fetch_array($check_query)){
 6     echo '错误:用户名 ',$username,' 已存在。<a href="javascript:history.back(-1);">返回</a>';
 7     exit;
 8 }
 9 //写入数据
10 $password = MD5($password);
11 $regdate = time();
12 $sql = "INSERT INTO user(username,password,email,regdate)VALUES('$username','$password','$email',
13 $regdate)";
14 if(mysql_query($sql,$conn)){
15     exit('用户注册成功!点击此处 <a href="login.html">登录</a>');
16 } else {
17     echo '抱歉!添加数据失败:',mysql_error(),'<br />';
18     echo '点击此处 <a href="javascript:history.back(-1);">返回</a> 重试';
19 }

该段代码首先检测用户名是否已经存在,如果存在则输出提示信息并立即终止程序执行。如果用户名不存在则把注册信息写入数据库,并输出对应提示信息。

posted @ 2016-09-23 10:41  纸飞机的梦想  阅读(5067)  评论(1编辑  收藏  举报