## 注册功能
模板所在位置: `/theme/default/reg.html`
PHP页面 `reg.php`
> 需要完成的功能点:
1 对输入项要进行魔术转义,防止SQL注入;
2 验证邮箱格式;
3 验证密码:长度,并校验两次输入是否一致;
4 校验数据库中是否存在改用户名;
5 校验图片验证码输入是否正确;
6 若全部校验通过则创建用户,并自动登录,登陆状态使用`Cookie`记录;
7 注册成功,赠送积分;
~~~
<?php
include './common/common.php';
$title = '用户注册 - ' . WEB_NAME;
//验证是否为提交注册信息
if (!empty($_POST['regsubmit']))
{
$uname = strMagic($_POST['username']);
$upass = trim($_POST['password']);
$urpass = trim($_POST['repassword']);
$umail = $_POST['mail'];
$pyzm = $_POST['yzm'];
//错误跳转页默认值
$url = $_SERVER['HTTP_REFERER'];
$style = 'alert_error';
$toTime = 3000;
$alterNotice = false; //提示页面标记位
//验证用户名长度
if(stringLen($uname))
{
$alterNotice = true;
$msgArr[] = '<font color=red><b>用户名长度错误:用户名由 3 到 12 个字符组成</b></font>';
}
//判断数据库里是否存在这个用户名
$exists = dbSelect('user','uid', 'username="'.$uname.'"','uid desc',1);
if($exists)
{
$alterNotice = true;
$msgArr[] = '<font color=red><b>用户名已存在</b></font>';
}
//验证密码长度
if(stringLen($upass))
{
$alterNotice = true;
$msgArr[] = '<font color=red><b>密码长度错误:由 3 到 12 个字符组成</b></font>';
}
//验证两次密码是否一致
if(str2Equal($upass, $urpass))
{
$alterNotice = true;
$msgArr[] = '<font color=red><b>错误:两次密码不一致</b></font>';
}
//验证email
if(checkEmail($umail))
{
$alterNotice = true;
$msgArr[] = '<font color=red><b>错误:邮箱不合法</b></font>';
}
//判断验证码
if(checkVerify($pyzm, $_SESSION['code']))
{
$alterNotice = true;
$msgArr[] = '<font color=red><b>验证码输入错误</b></font>';
}
//验证是否需要显示提示信息
if($alterNotice)
{
$msg = join('<br />', $msgArr);
include 'notice.php';
exit;
}
//创建用户
$money = REWARD_REG;
$n = 'username, password, email, udertype, regtime, lasttime, regip, grade';
$v = "'$uname', '".md5($upass)."', '$umail', 0, ".time().", ".time().", ".ip2long($_SERVER['REMOTE_ADDR']).", ".$money;
$result = dbInsert('user', $n, $v);
if(!$result)
{
$msg = '<font color=red><b>注册失败,请联系管理员</b></font>';
include 'notice.php';
}else{
//注册成功后自动登录
$result = dbSelect('user', 'uid,username,udertype,picture,grade', 'username="'.$uname.'" and password="'.md5($upass).'"', 'uid desc', 1);
setcookie('uid',$result[0]['uid'],time()+86400);
setcookie('username',$result[0]['username'],time()+2592000);
setcookie('udertype',$result[0]['udertype'],time()+86400);
setcookie('picture',$result[0]['picture'],time()+86400);
setcookie('grade',$result[0]['grade'],time()+86400);
$msg = '<font color=green><b>感谢您的注册,现在将以会员身份登录站点</b></font>';
$url = 'index.php';
$style = 'alert_right';
include 'notice.php';
$msg = '注册赠送';
include 'layer.php';
}
}else{
include template("reg.html");
}
?>
~~~
## 用户登陆
PHP页面 `login.php`
> 需要完成的功能点:
1 自动登陆功能,通过设置`Cookie`的过期时间来验证是否使用了自动登陆,有效期为30天。若浏览器`Cookie`被清除则自动失效;
2 验证登陆账号是否被管理员从后台锁定;
3 记录用户最后登陆时间;
~~~
<?php
include './common/common.php';
$username = strMagic($_POST['username']);
$password = trim($_POST['password']);
$cookietime = $_POST['cookietime'];
$result = dbSelect('user','uid,username,udertype,picture,grade,allowlogin,lasttime', 'username="'.$username.'" and password="'.md5($password).'"');
//判断是否使用了自动登录
if($cookietime)
{
$longTime = time()+2592000;
}else{
$longTime = time()+86400;
}
if(!$result)
{
$msg = '<font color=red><b>登录失败,用户名或密码错误</b></font>';
$url = $_SERVER['HTTP_REFERER'];
$style = 'alert_error';
$toTime = 3000;
include 'notice.php';
}else{
if($result[0]['allowlogin'])
{
$msg = '<font color=red><b>您的账号已经被锁定,请联系管理员</b></font>';
$url = $_SERVER['HTTP_REFERER'];
$style = 'alert_error';
$toTime = 3000;
include 'notice.php';
exit;
}
$money = REWARD_LOGIN;
if(formatTime($result[0]['lasttime'])<date('Y-m-d'))
{
//更新最后登录时间,首次登陆还要加积分
$lasttime = dbUpdate('user', 'lasttime='.time().',grade=grade+'.(int)$money.'', 'uid='.$result[0]['uid'].'');
$first = true;
$grade = $result[0]['grade']+(int)$money;
}else{
//更新最后登录时间
$lasttime = dbUpdate('user', 'lasttime='.time().'', 'uid='.$result[0]['uid'].'');
$grade = $result[0]['grade'];
}
setcookie('uid',$result[0]['uid'],$longTime);
setcookie('username',$result[0]['username'],time()+2592000);
setcookie('udertype',$result[0]['udertype'],$longTime);
setcookie('picture',$result[0]['picture'],$longTime);
setcookie('grade',$grade,$longTime);
$msg = '<font color=green><b>登录成功</b></font>';
$url = $_SERVER['HTTP_REFERER'];
$style = 'alert_right';
$toTime = 3000;
include 'notice.php';
if($first)
{
$msg = '每天登陆';
include 'layer.php';
}
}
~~~
## 退出登陆状态
PHP页面 `logout.php`
> Cookie 时间设置为当前时间-1,视为立即失效;
~~~
<?php
include './common/common.php';
setcookie('uid','',time()-1);
setcookie('udertype','',time()-1);
setcookie('picture','',time()-1);
setcookie('grade','',time()-1);
$msg = '<font color=green><b>您已退出站点,现在将以游客身份转入退出前页面</b></font>';
$url = 'index.php';
$style = 'alert_right';
$toTime = 3000;
include 'notice.php';
~~~
退出成功后,跳转到首页。
- 01. 为什么选择本书学习PHP
- 1.1 为什么学习PHP?
- 1.2 PHP是什么
- 1.3 零基础也能学习
- 1.4 为什么有些人学不会
- 02.PHP的环境安装
- 2.1开发环境是什么?
- 2.2 windows环境安装
- 2.3 Linux环境安装
- 2.4 其他开发环境
- 2.5 写代码的工具选择
- 03. PHP基本语法
- 3.1 PHP基本语法
- 3.1.1 写出你的第一段PHP代码
- 3.1.2 读过初中你就会变量
- 3.1.3 echo 显示命令
- 3.1.4 注释的功能很强大
- 3.2 数据类型并不神秘
- 3.2.1 整型就是整数
- 3.2.2 布尔就是易经的知识
- 3.2.3 字符串
- 3.2.4 浮点型
- 3.2.5 重要:if和else语法
- 3.2.6 NULL类型
- 3.2.7对象以后会学
- 3.2.8 数组会有单纯的一个章节
- 3.2.9 资源类型
- 3.2.10 眼前了解回调类型即可
- 3.2.11 查看和判断数据类型
- 3.2.12 数据类型的自动转换和强制转换
- 3.3 常量和变量
- 3.3.1 用常量限制用户跳过某些文件
- 3.3.2 可变变量
- 3.3.3 外部变量
- 3.3.4 环境变量
- 3.3.5 变量引用
- 3.4 PHP表达式与运算符
- 3.4.1 算术运算
- 3.4.2 赋值运算
- 3.4.3 自加、自减运算
- 3.4.4 比较运算
- 3.4.5 逻辑运算
- 3.4.6 位运算
- 3.4.7 运算符优先级
- 3.4.8 三元运算符和其它运算符
- 04. PHP中的流程控制
- 4.1 if条件结构流程
- 4.1.1 if语句
- 4.1.2 嵌套if...else...elseif结构
- 4.1.3 if语句多种嵌套
- 4.2 分支结构switch语句的使用
- 4.3 循环语句的使用
- 4.3.1 while循环
- 4.3.2 do...while循环的区别
- 4.3.3 for循环控制语句
- 4.3.4 goto语法
- 4.3.5 declare 语法
- 05.PHP的函数基本语法
- 5.1 自定义函数
- 5.2 自定义函数高级调用
- 5.2.1 回调函数
- 5.2.2 变量函数
- 5.2.3 匿名函数
- 5.2.4 内部函数
- 5.2.5 变量作用域
- 5.2.6 参数的引用
- 5.2.7 递归函数
- 5.2.8 静态变量
- 5.3 使用系统内置函数
- 5.4 文件包含函数
- 5.5 数学常用函数
- 5.6 日期常用函数
- 5.6.1 获取时期时间信息函数
- 5.6.2 日期验证函数
- 5.6.3 获取本地化时间戳函数
- 5.6.4 程序执行时间检测
- 5.7 字符串常用函数
- 06.PHP数组与数据结构
- 6.1 数组的定义
- 6.2 数组的操作
- 6.2.1 数组的计算
- 6.2.2 for循环遍历索引数组
- 6.2.3 foreach遍历关联数组
- 6.2.4 list、each函数遍历数组
- 6.2.5 常用操作数组函数
- 6.3 数组的常用函数
- 07. PHP中的正则达达式
- 7.1 正则表达示的定界符
- 7.2 正则表达示中的原子
- 7.3 正则表示中的元字符
- 7.4 正则达达示中的模式修正符
- 7.5 写正则的诀窍和常用正则
- 7.6 用正则写一个UBB文本编辑器
- 08.文件系统
- 8.1 读取文件
- 8.2 创建和修改文件内容
- 8.3 创建临时文件
- 8.4 移动、拷贝和删除文件
- 8.5 检测文件属性函数
- 8.6 文件常用函数和常量
- 8.7 文件锁处机制
- 8.8 目录处理函数
- 8.9 文件权限设置
- 8.10文件路径函数
- 8.11 小小文件留言本
- 8.12 修改配置文件的实例
- 09.PHP文件上传
- 9.1 文件上传需要注意php.ini文件
- 9.2 文件上传的步骤
- 9.3 文件上传表单注意事项
- 9.4 按照数组和步骤完成文件上传
- 9.5 多文件上传
- 9.6 文件上传进度处理
- 10.PHP图像处理
- 10.1 学习前的准备工作
- 10.2 用图片处理函数画一张图
- 10.3 生成验证码
- 10.4 图像缩放和裁剪技术
- 10.5 图片水印处理
- 11.错误处理
- 11.1 禁止显示错误
- 11.2 错误报告级别
- 11.3 错误记录日志
- 11.4 自定义错误处理函数
- 12.MySQL 入门
- 12.1 请进入《MySQL入门》
- 13. PHP操作mysql数据库
- 13.1 数据库连接步骤
- 13.2 通过步骤做一个用户注册
- 13.3 通过步骤做一个列表显示
- 13.4 把用户做个分页
- 13.5 批量和指定删除用户
- 13.6 修改用户信息
- 13.7 数据显示乱码终极解决办法
- 14.会话管理和控制
- 14.1 Cookie概述
- 14.2PHP中的Cookie
- 14.3 session概述
- 14.4 PHP中使用session
- 14.5 SESSION应用实例
- 15.通过cURL来做小偷程序
- 15.1 curl的使用步骤
- 15.2 自定义get方法抓取网页
- 15.3 使用post发送数据
- 16. 用PHP写一个论坛
- 16.1 web2.0始于论坛
- 16.2 需求:开发前你要知道他的样子
- 16.3 核心业务流程
- 16.3.1 用户注册流程
- 16.3.2 普通用户和管理员登陆流程
- 16.3.3 发贴流程
- 16.3.4 回复流程
- 16.3.5 版块管理流程
- 16.3.6 版主业务流程
- 16.3.7 金币奖励和消耗流程
- 16.4 数据库表设计
- 16.5 文件和代码规范
- 16.6 核心功能说明
- 16.6.1 项目目录结构说明
- 16.6.2 公共文件的使用
- 16.6.3 模板引擎讲解
- 16.6.4 用户注册、登陆功能讲解
- 16.6.5 发帖功能讲解
- 16.6.6 回帖功能讲解
- 16.6.7 项目安装模块讲解
- 附录1. 版权声明
- 附录2 . 学习PHP常用的英文单词