tp登陆注册(转)
登录时,更新用户数据,登录ip和登录时间,以及登录次数+1,此实现方便不知是否合适,待验证。
源码地址:https://github.com/grh0812/thinkphp-login-register
创建数据库 :
/*
Navicat MySQL Data Transfer Source Server : 本地连接
Source Server Version : 50617
Source Host : localhost:3306
Source Database : crm Target Server Type : MYSQL
Target Server Version : 50617
File Encoding : 65001 Date: 2015-06-29 23:55:28
*/ 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 BTREE
) 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'];
$result = $login->where($where)->field('userid,username,nickname,password,lastdate,lastip')->find(); // 验证用户名 对比 密码
if ($result && $result['password'] == $result['password']) {
// 存储session
session('uid', $result['userid']); // 当前用户id
session('nickname', $result['nickname']); // 当前用户昵称
session('username', $result['username']); // 当前用户名
session('lastdate', $result['lastdate']); // 上一次登录时间
session('lastip', $result['lastip']); // 上一次登录ip // 更新用户登录信息
$where['userid'] = session('uid');
M('users')->where($where)->setInc('loginnum'); // 登录次数加 1
M('users')->where($where)->save($data); // 更新登录时间和登录ip $this->success('登录成功,正跳转至系统首页...', U('Index/index'));
} else {
$this->error('登录失败,用户名或密码不正确!');
}
} else {
$this->display();
}
} /**
* 用户注册
*/
public function register()
{
// 判断提交方式 做不同处理
if (IS_POST) {
// 实例化User对象
$user = D('users'); // 自动验证 创建数据集
if (!$data = $user->create()) {
// 防止输出中文乱码
header("Content-type: text/html; charset=utf-8");
exit($user->getError());
} //插入数据库
if ($id = $user->add($data)) {
/* 直接注册用户为超级管理员,子用户采用邀请注册的模式,
遂设置公司id等于注册用户id,便于管理公司用户*/
$user->where("userid = $id")->setField('companyid', $id);
$this->success('注册成功', U('Index/index'), 2);
} else {
$this->error('注册失败');
}
} else {
$this->display();
}
} /**
* 用户注销
*/
public function logout()
{
// 清楚所有session
session(null);
redirect(U('Login/login'), 2, '正在退出登录...');
} /**
* 验证码
*/
public function verify()
{
// 实例化Verify对象
$verify = new \Think\Verify(); // 配置验证码参数
$verify->fontSize = 14; // 验证码字体大小
$verify->length = 4; // 验证码位数
$verify->imageH = 34; // 验证码高度
$verify->useImgBg = true; // 开启验证码背景
$verify->useNoise = false; // 关闭验证码干扰杂点
$verify->entry();
}
}
登录模版 :
<form action="__SELF__" method="post">
<div class="form-group has-feedback">
<input type="text" name="username" class="form-control" placeholder="用户名" />
<span class="glyphicon glyphicon-user form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="password" name="password" class="form-control" placeholder="密码" />
<span class="glyphicon glyphicon-lock form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="text" name="verify" class="form-control" placeholder="验证码" style="width:200px;" />
<span class="glyphicon glyphicon-qrcode form-control-feedback" style="right:120px;"></span>
<img class="verify" src="{:U(verify)}" alt="验证码" onClick="this.src=this.src+'?'+Math.random()" />
</div>
<div class="row">
<div class="col-xs-8">
<div class="checkbox icheck">
<label>
<input type="checkbox" name="remember" value="1"> 记住我
</label>
</div>
</div><!-- /.col -->
<div class="col-xs-4">
<button type="submit" class="btn btn-primary btn-block btn-flat">登录</button>
</div><!-- /.col -->
</div>
</form>
注册模版 :
<div class="register-box-body">
<p class="login-box-msg">注册一个新用户</p>
<form action="__SELF__" method="post">
<div class="form-group has-feedback">
<input type="text" name="nickname" class="form-control" placeholder="昵称" />
<span class="glyphicon glyphicon-leaf form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="text" name="username" class="form-control" placeholder="用户名" />
<span class="glyphicon glyphicon-user form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="password" name="password" class="form-control" placeholder="密码" />
<span class="glyphicon glyphicon-credit-card form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="password" name="repassword" class="form-control" placeholder="确认密码" />
<span class="glyphicon glyphicon-check form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="email" name="email" class="form-control" placeholder="邮箱" />
<span class="glyphicon glyphicon-envelope form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="text" name="mobile" class="form-control" placeholder="手机号码" />
<span class="glyphicon glyphicon-phone form-control-feedback"></span>
</div>
<div class="form-group has-feedback">
<input type="text" name="verify" class="form-control" placeholder="验证码" style="width:200px;" />
<span class="glyphicon glyphicon-qrcode form-control-feedback" style="right:120px;"></span>
<img class="verify" src="{:U(verify)}" alt="验证码" onClick="this.src=this.src+'?'+Math.random()" />
</div>
<div class="row">
<div class="col-xs-8">
<div class="checkbox icheck">
<label>
<input type="checkbox" name="agree" value="1"> 我同意 <a href="#">网站安全协议</a>
</label>
</div>
</div><!-- /.col -->
<div class="col-xs-4">
<button type="submit" class="btn btn-primary btn-block btn-flat">点击注册</button>
</div><!-- /.col -->
</div>
</form>
<a href="login.html" class="text-center">我已经注册了账户</a>
</div>
tp登陆注册(转)的更多相关文章
- Android通过Http连接MySQL 实现登陆/注册(数据库+服务器+客户端)
写在最前: 在实际开发中,相信每个项目都会有用户登陆注册功能,这个实现的方法很多,下面是我实现的方法,供大家交流. 新人发帖,万分紧张,怎么样才能装作一副经常发帖的样子不被别人看出来呢-,- ? 好了 ...
- java 24 - 11 GUI之制作登陆注册页面
简单说说,懒得发了... 步骤: A:首先写出登陆注册需要用到类以及代码(IO流) B:然后创建登陆窗口和注册窗口 C:各个监听事件: a:登录窗口 1.重置:把2个文本框的内容全部清空 2.注册:关 ...
- PHP数据库登陆注册简单做法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- javaweb 登陆注册页面
视图的数据修改,表中也修改引用工具类用<%@ page import=""%> <%@ page import="java.util.Date" ...
- 用户登陆注册【JDBC版】
前言 在讲解Web开发模式的时候,曾经写过XML版的用户登陆注册案例!现在在原有的项目上,使用数据库版来完成用户的登陆注册!如果不了解的朋友,可以看看我Web开发模式的博文! 本来使用的是XML文件作 ...
- 用ajax的同步请求解决登陆注册需要根据服务器返回数据判断是否能提交的问题
最近在写www.doubilaile.com的登陆注册.需要用ajax请求服务器判断用户名是否存在,用户名和密码是否匹配,进而提交数据.碰到的问题是异步请求都能成功返回数据,但是该数据不能作为紧接着的 ...
- tkinter 创建登陆注册界面
import tkinter as tk from tkinter import messagebox #设置窗口居中 def window_info(): ws = window.winfo_scr ...
- 《java入门第一季》模拟用户登陆注册案例集合版
需求:校验用户名和密码,登陆成功后玩猜数字小游戏. 在这里先写集合版.后面还有IO版.数据库版. 一.猜数字小游戏类: 猜数字小游戏的代码见博客:http://blog.csdn.net/qq_320 ...
- IdentityServer4【Topic】之登陆注册
Sign-in 登陆注册 为了让标识服务器(identity server)代表用户发出令牌,该用户必须登录到标识服务器. Cookie authentication Cookie认证 身份验证是由来 ...
随机推荐
- html中布局,让下一个子元素占据剩余的高度
---------------------------------------------------------------------- 原因是: height:100% 引起的, 这句话的意思是 ...
- 云计算VDI相关职位招聘
中电科华云信息技术有限公司是中国优秀的云计算方案提供商和服务商之中的一个.公司依托中国电子科技集团公司,实施"自主.可信.定制.服务"的差异化发展战略,以实现自主创新的技术研发.自 ...
- 第6章1节《MonkeyRunner源代码剖析》Monkey原理分析-事件源-事件源概览
在上一章中我们有简要的介绍了事件源是怎么一回事.可是并没有进行详细的描写叙述.那么往下的这几个小节我们就须要把这方面的知识给补充完整. 这一节我们先主要环绕MonkeySourceNetwork这个事 ...
- SSLStrip 终极版 —— location 瞒天过海
之前介绍了 HTTPS 前端劫持 的方案,尽管非常有趣.然而现实却并不理想. 其唯一.也是最大的缺陷.就是无法阻止脚本跳转.若是没有这个缺陷,那就非常完美了 -- 当然也就没有必要写这篇文章了. 说究 ...
- php 获取今天,本周,本月,三个月内,半年内,今年的开始和结束时间
$now = time(); //今天 $today_audit_num = 0; $today_use_num = 0; $beginTim ...
- Flask 解析 Web 端 请求 数组
Web前台由 JavaScript 通过Ajax发送POST请求,当请求数据为数组时,Python Flask 做服务器时的解析如下: js: var ids = []; for (var i = 0 ...
- ios跟踪工具introspy使用
1.cydia安装introspy,前提要安装Applist (雷锋源) 2.设置中有introspy-Apps instrospy-Settings选项. 可以选择需要跟踪的app以及跟踪内 ...
- 将JSON对象转换成IList,好用linq
JObject JToken JProperty IList<> 搞得头都大了,记而备忘: JObject json = ..... JToken[] jps = json["r ...
- 解决vs2010无法找到System.Data.OracleClient的引用问题
解决vs2010无法找到System.Data.OracleClient的引用问题 2012-2-19 09:12| 发布者: benben| 查看: 7627| 评论: 0 摘要: 在vs201 ...
- 【转载】limits.h
limits.h专门用于检测整型数据数据类型的表达值范围. <limits.h>主要提供对整型和字符型范围的限制的宏,同样没有指定类型和函数的定义. 1.整型宏如下表: 2.字符型宏如下表 ...