thinkphp实现注册登录功能
创建数据库 :
SET FOREIGN_KEY_CHECKS=0;
-- ----------------------------
-- Table structure for think_users
-- ----------------------------
DROP TABLE IF EXISTS `think_users`;
CREATE TABLE `think_users` (
`userid` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户id',
`companyid` mediumint(8) unsigned NOT NULL COMMENT '公司id',
`pid` mediumint(8) NOT NULL COMMENT '父id',
`username` char(20) NOT NULL DEFAULT '' COMMENT '用户名',
`password` char(32) NOT NULL DEFAULT '' COMMENT '密码',
`nickname` char(20) NOT NULL DEFAULT '' COMMENT '昵称',
`regdate` int(10) unsigned NOT NULL COMMENT '注册时间',
`lastdate` int(10) unsigned NOT NULL COMMENT '最后一次登录时间',
`regip` char(15) NOT NULL DEFAULT '' COMMENT '注册ip',
`lastip` char(15) NOT NULL DEFAULT '' COMMENT '最后一次登录ip',
`loginnum` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '登录次数',
`email` char(32) NOT NULL DEFAULT '' COMMENT '邮箱',
`mobile` char(11) NOT NULL DEFAULT '' COMMENT '手机号码',
`islock` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否锁定',
`vip` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否会员',
`overduedate` int(10) unsigned NOT NULL COMMENT '账户过期时间',
`status` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '状态-用于软删除',
PRIMARY KEY (`userid`),
UNIQUE KEY `username` (`username`) USING BTREE,
KEY `email` (`email`) USING BTREEdrop table if exists user
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
创建模型(用于自动验证, 自动完成) :
namespace Home\Model;
use Think\Model;
class UsersModel extends Model {
/**
* 自动验证
* self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)
* self::MUST_VALIDATE 或者1 必须验证
* self::VALUE_VALIDATE或者2 值不为空的时候验证
*/
protected $_validate = array(
array('nickname', 'require', '昵称不能为空!'), //默认情况下用正则进行验证
array('username', 'require', '用户名不能为空!'), //默认情况下用正则进行验证
array('username', '', '该用户名已被注册!', 0, 'unique', 1), // 在新增的时候验证name字段是否唯一
array('email', '', '该邮箱已被占用', 0, 'unique', 1), // 新增的时候email字段是否唯一
array('mobile', '', '该手机号码已被占用', 0, 'unique', 1), // 新增的时候mobile字段是否唯一
// 正则验证密码 [需包含字母数字以及@*#中的一种,长度为6-22位]
array('password', '/^([a-zA-Z0-9@*#]{6,22})$/', '密码格式不正确,请重新输入!', 0),
array('repassword', 'password', '确认密码不正确', 0, 'confirm'), // 验证确认密码是否和密码一致
array('email', 'email', '邮箱格式不正确'), // 内置正则验证邮箱格式
array('mobile', '/^1[34578]\d{9}$/', '手机号码格式不正确', 0), // 正则表达式验证手机号码
array('verify', 'verify_check', '验证码错误', 0, 'function'), // 判断验证码是否正确
//array('agree', 'is_agree', '请先同意网站安全协议!', 1, 'callback'), // 判断是否勾选网站安全协议
array('agree', 'require', '请先同意网站安全协议!', 1), // 判断是否勾选网站安全协议
);
/**
* 自动完成
*/
protected $_auto = array (
array('password', 'md5', 3, 'function') , // 对password字段在新增和编辑的时候使md5函数处理
array('regdate', 'time', 1, 'function'), // 对regdate字段在新增的时候写入当前时间戳
array('regip', 'get_client_ip', 1, 'function'), // 对regip字段在新增的时候写入当前注册ip地址
);
/**
* 判断是否同意网站安全管理协议
* @return bool
*/
protected function is_agree()
{
// 获取POST数据
$agree = I('post.agree', 0, 'intval');
// 验证
if ($agree) {
return true;
} else {
return false;
}
}
登录注册 :
namespace Home\Controller;
use Think\Controller;
/**
* Class LoginController
* @package Home\Controller
*/
class LoginController extends Controller {
/**
* 用户登录
*/
public function login()
{
// 判断提交方式
if (IS_POST) {
// 实例化Login对象
$login = D('login');
// 自动验证 创建数据集
if (!$data = $login->create()) {
// 防止输出中文乱码
header("Content-type: text/html; charset=utf-8");
exit($login->getError());
}
// 组合查询条件
$where = array();
$where['username'] = $data['username'];