登陆注册

thinkphp实现注册登录功能

浏览:25238 发布日期:2015/06/30 分类:技术分享 关键字: thinkphp 登录 注册

使用最新的thinkphp3.2.3版本,需要注意命名空间的使用。
均为后台验证,前台ajax验证未做处理。后续加上。。。
登录时,更新用户数据,登录ip和登录时间,以及登录次数+1,此实现方便不知是否合适,待验证。
源码地址:https://github.com/grh0812/thinkphp-login-register

创建数据库 :

  1. /*
  2. Navicat MySQL Data Transfer
  3. Source Server         : 本地连接
  4. Source Server Version : 50617
  5. Source Host           : localhost:3306
  6. Source Database       : crm
  7. Target Server Type    : MYSQL
  8. Target Server Version : 50617
  9. File Encoding         : 65001
  10. Date: 2015-06-29 23:55:28
  11. */
  12. SET FOREIGN_KEY_CHECKS=0;
  13. -- ----------------------------
  14. -- Table structure for think_users
  15. -- ----------------------------
  16. DROP TABLE IF EXISTS `think_users`;
  17. CREATE TABLE `think_users` (
  18. `userid` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘用户id‘,
  19. `companyid` mediumint(8) unsigned NOT NULL COMMENT ‘公司id‘,
  20. `pid` mediumint(8) NOT NULL COMMENT ‘父id‘,
  21. `username` char(20) NOT NULL DEFAULT ‘‘ COMMENT ‘用户名‘,
  22. `password` char(32) NOT NULL DEFAULT ‘‘ COMMENT ‘密码‘,
  23. `nickname` char(20) NOT NULL DEFAULT ‘‘ COMMENT ‘昵称‘,
  24. `regdate` int(10) unsigned NOT NULL COMMENT ‘注册时间‘,
  25. `lastdate` int(10) unsigned NOT NULL COMMENT ‘最后一次登录时间‘,
  26. `regip` char(15) NOT NULL DEFAULT ‘‘ COMMENT ‘注册ip‘,
  27. `lastip` char(15) NOT NULL DEFAULT ‘‘ COMMENT ‘最后一次登录ip‘,
  28. `loginnum` smallint(5) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘登录次数‘,
  29. `email` char(32) NOT NULL DEFAULT ‘‘ COMMENT ‘邮箱‘,
  30. `mobile` char(11) NOT NULL DEFAULT ‘‘ COMMENT ‘手机号码‘,
  31. `islock` tinyint(1) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘是否锁定‘,
  32. `vip` tinyint(1) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘是否会员‘,
  33. `overduedate` int(10) unsigned NOT NULL COMMENT ‘账户过期时间‘,
  34. `status` tinyint(1) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘状态-用于软删除‘,
  35. PRIMARY KEY (`userid`),
  36. UNIQUE KEY `username` (`username`) USING BTREE,
  37. KEY `email` (`email`) USING BTREE
  38. ) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;

复制代码

创建模型(用于自动验证, 自动完成) :

  1. namespace Home\Model;
  2. use Think\Model;
  3. class UsersModel extends Model {
  4. /**
  5. * 自动验证
  6. * self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)
  7. * self::MUST_VALIDATE 或者1 必须验证
  8. * self::VALUE_VALIDATE或者2 值不为空的时候验证
  9. */
  10. protected $_validate = array(
  11. array(‘nickname‘, ‘require‘, ‘昵称不能为空!‘), //默认情况下用正则进行验证
  12. array(‘username‘, ‘require‘, ‘用户名不能为空!‘), //默认情况下用正则进行验证
  13. array(‘username‘, ‘‘, ‘该用户名已被注册!‘, 0, ‘unique‘, 1), // 在新增的时候验证name字段是否唯一
  14. array(‘email‘, ‘‘, ‘该邮箱已被占用‘, 0, ‘unique‘, 1), // 新增的时候email字段是否唯一
  15. array(‘mobile‘, ‘‘, ‘该手机号码已被占用‘, 0, ‘unique‘, 1), // 新增的时候mobile字段是否唯一
  16. // 正则验证密码 [需包含字母数字以及@*#中的一种,长度为6-22位]
  17. array(‘password‘, ‘/^([[email protected]*#]{6,22})$/‘, ‘密码格式不正确,请重新输入!‘, 0),
  18. array(‘repassword‘, ‘password‘, ‘确认密码不正确‘, 0, ‘confirm‘), // 验证确认密码是否和密码一致
  19. array(‘email‘, ‘email‘, ‘邮箱格式不正确‘), // 内置正则验证邮箱格式
  20. array(‘mobile‘, ‘/^1[34578]\d{9}$/‘, ‘手机号码格式不正确‘, 0), // 正则表达式验证手机号码
  21. array(‘verify‘, ‘verify_check‘, ‘验证码错误‘, 0, ‘function‘), // 判断验证码是否正确
  22. //array(‘agree‘, ‘is_agree‘, ‘请先同意网站安全协议!‘, 1, ‘callback‘), // 判断是否勾选网站安全协议
  23. array(‘agree‘, ‘require‘, ‘请先同意网站安全协议!‘, 1), // 判断是否勾选网站安全协议
  24. );
  25. /**
  26. * 自动完成
  27. */
  28. protected $_auto = array (
  29. array(‘password‘, ‘md5‘, 3, ‘function‘) , // 对password字段在新增和编辑的时候使md5函数处理
  30. array(‘regdate‘, ‘time‘, 1, ‘function‘), // 对regdate字段在新增的时候写入当前时间戳
  31. array(‘regip‘, ‘get_client_ip‘, 1, ‘function‘), // 对regip字段在新增的时候写入当前注册ip地址
  32. );
  33. /**
  34. * 判断是否同意网站安全管理协议
  35. * @return bool
  36. */
  37. protected function is_agree()
  38. {
  39. // 获取POST数据
  40. $agree = I(‘post.agree‘, 0, ‘intval‘);
  41. // 验证
  42. if ($agree) {
  43. return true;
  44. } else {
  45. return false;
  46. }
  47. }

复制代码

登录注册 :

  1. namespace Home\Controller;
  2. use Think\Controller;
  3. /**
  4. * Class LoginController
  5. * @package Home\Controller
  6. */
  7. class LoginController extends Controller {
  8. /**
  9. * 用户登录
  10. */
  11. public function login()
  12. {
  13. // 判断提交方式
  14. if (IS_POST) {
  15. // 实例化Login对象
  16. $login = D(‘login‘);
  17. // 自动验证 创建数据集
  18. if (!$data = $login->create()) {
  19. // 防止输出中文乱码
  20. header("Content-type: text/html; charset=utf-8");
  21. exit($login->getError());
  22. }
  23. // 组合查询条件
  24. $where = array();
  25. $where[‘username‘] = $data[‘username‘];
  26. $result = $login->where($where)->field(‘userid,username,nickname,password,lastdate,lastip‘)->find();
  27. // 验证用户名 对比 密码
  28. if ($result && $result[‘password‘] == $result[‘password‘]) {
  29. // 存储session
  30. session(‘uid‘, $result[‘userid‘]);          // 当前用户id
  31. session(‘nickname‘, $result[‘nickname‘]);   // 当前用户昵称
  32. session(‘username‘, $result[‘username‘]);   // 当前用户名
  33. session(‘lastdate‘, $result[‘lastdate‘]);   // 上一次登录时间
  34. session(‘lastip‘, $result[‘lastip‘]);       // 上一次登录ip
  35. // 更新用户登录信息
  36. $where[‘userid‘] = session(‘uid‘);
  37. M(‘users‘)->where($where)->setInc(‘loginnum‘);   // 登录次数加 1
  38. M(‘users‘)->where($where)->save($data);   // 更新登录时间和登录ip
  39. $this->success(‘登录成功,正跳转至系统首页...‘, U(‘Index/index‘));
  40. } else {
  41. $this->error(‘登录失败,用户名或密码不正确!‘);
  42. }
  43. } else {
  44. $this->display();
  45. }
  46. }
  47. /**
  48. * 用户注册
  49. */
  50. public function register()
  51. {
  52. // 判断提交方式 做不同处理
  53. if (IS_POST) {
  54. // 实例化User对象
  55. $user = D(‘users‘);
  56. // 自动验证 创建数据集
  57. if (!$data = $user->create()) {
  58. // 防止输出中文乱码
  59. header("Content-type: text/html; charset=utf-8");
  60. exit($user->getError());
  61. }
  62. //插入数据库
  63. if ($id = $user->add($data)) {
  64. /* 直接注册用户为超级管理员,子用户采用邀请注册的模式,
  65. 遂设置公司id等于注册用户id,便于管理公司用户*/
  66. $user->where("userid = $id")->setField(‘companyid‘, $id);
  67. $this->success(‘注册成功‘, U(‘Index/index‘), 2);
  68. } else {
  69. $this->error(‘注册失败‘);
  70. }
  71. } else {
  72. $this->display();
  73. }
  74. }
  75. /**
  76. * 用户注销
  77. */
  78. public function logout()
  79. {
  80. // 清楚所有session
  81. session(null);
  82. redirect(U(‘Login/login‘), 2, ‘正在退出登录...‘);
  83. }
  84. /**
  85. * 验证码
  86. */
  87. public function verify()
  88. {
  89. // 实例化Verify对象
  90. $verify = new \Think\Verify();
  91. // 配置验证码参数
  92. $verify->fontSize = 14;     // 验证码字体大小
  93. $verify->length = 4;        // 验证码位数
  94. $verify->imageH = 34;       // 验证码高度
  95. $verify->useImgBg = true;   // 开启验证码背景
  96. $verify->useNoise = false;  // 关闭验证码干扰杂点
  97. $verify->entry();
  98. }
  99. }

复制代码

登录模版 :

  1. <form action="__SELF__" method="post">
  2. <div class="form-group has-feedback">
  3. <input type="text" name="username" class="form-control" placeholder="用户名" />
  4. <span class="glyphicon glyphicon-user form-control-feedback"></span>
  5. </div>
  6. <div class="form-group has-feedback">
  7. <input type="password" name="password" class="form-control" placeholder="密码" />
  8. <span class="glyphicon glyphicon-lock form-control-feedback"></span>
  9. </div>
  10. <div class="form-group has-feedback">
  11. <input type="text" name="verify" class="form-control" placeholder="验证码" style="width:200px;" />
  12. <span class="glyphicon glyphicon-qrcode form-control-feedback" style="right:120px;"></span>
  13. <img class="verify" src="{:U(verify)}" alt="验证码" onClick="this.src=this.src+‘?‘+Math.random()" />
  14. </div>
  15. <div class="row">
  16. <div class="col-xs-8">
  17. <div class="checkbox icheck">
  18. <label>
  19. <input type="checkbox" name="remember" value="1"> 记住我
  20. </label>
  21. </div>
  22. </div><!-- /.col -->
  23. <div class="col-xs-4">
  24. <button type="submit" class="btn btn-primary btn-block btn-flat">登录</button>
  25. </div><!-- /.col -->
  26. </div>
  27. </form>

复制代码

注册模版 :

  1. <div class="register-box-body">
  2. <p class="login-box-msg">注册一个新用户</p>
  3. <form action="__SELF__" method="post">
  4. <div class="form-group has-feedback">
  5. <input type="text" name="nickname" class="form-control" placeholder="昵称" />
  6. <span class="glyphicon glyphicon-leaf form-control-feedback"></span>
  7. </div>
  8. <div class="form-group has-feedback">
  9. <input type="text" name="username" class="form-control" placeholder="用户名" />
  10. <span class="glyphicon glyphicon-user form-control-feedback"></span>
  11. </div>
  12. <div class="form-group has-feedback">
  13. <input type="password" name="password" class="form-control" placeholder="密码" />
  14. <span class="glyphicon glyphicon-credit-card form-control-feedback"></span>
  15. </div>
  16. <div class="form-group has-feedback">
  17. <input type="password" name="repassword" class="form-control" placeholder="确认密码" />
  18. <span class="glyphicon glyphicon-check form-control-feedback"></span>
  19. </div>
  20. <div class="form-group has-feedback">
  21. <input type="email" name="email" class="form-control" placeholder="邮箱" />
  22. <span class="glyphicon glyphicon-envelope form-control-feedback"></span>
  23. </div>
  24. <div class="form-group has-feedback">
  25. <input type="text" name="mobile" class="form-control" placeholder="手机号码" />
  26. <span class="glyphicon glyphicon-phone form-control-feedback"></span>
  27. </div>
  28. <div class="form-group has-feedback">
  29. <input type="text" name="verify" class="form-control" placeholder="验证码" style="width:200px;" />
  30. <span class="glyphicon glyphicon-qrcode form-control-feedback" style="right:120px;"></span>
  31. <img class="verify" src="{:U(verify)}" alt="验证码" onClick="this.src=this.src+‘?‘+Math.random()" />
  32. </div>
  33. <div class="row">
  34. <div class="col-xs-8">
  35. <div class="checkbox icheck">
  36. <label>
  37. <input type="checkbox" name="agree" value="1"> 我同意 <a href="#">网站安全协议</a>
  38. </label>
  39. </div>
  40. </div><!-- /.col -->
  41. <div class="col-xs-4">
  42. <button type="submit" class="btn btn-primary btn-block btn-flat">点击注册</button>
  43. </div><!-- /.col -->
  44. </div>
  45. </form>
  46. <a href="login.html" class="text-center">我已经注册了账户</a>
  47. </div>

复制代码

困扰: 
注册的账户全都是管理员账户, 子账户采用邀请注册的方式, 
如果以公司为单位的话 公司的id等于注册用户的id, 员工就是公司管理员邀请注册, 用户表里有个companyid=userid(管理员), 
现在的实现方法是 插入之后获取userid 然后在更新到companyid 
有木有什么办法可以直接插入?
请求各位大神 提各种意见 帮助小弟提升. 跪谢不起... ^_^

评论(11)相关

zhangxian33308月29日

楼主你好,登录注册控制器那部分代码的第17行是写错了吗?
$login = D(‘login‘);
是不是应该修改为
$login = D(‘users‘);
这样子?

回复土掉渣Boy09月07日

抱歉哈,有很多错误的地方没修改

回复zhangxian33309月16日

回复 土掉渣Boy : 没关系,我是新手。create困扰我很久了,你的代码对我帮助很大。

回复小天才前天 15:11

$login = D(‘login‘);
这一句是对的,因为楼主已经在LoginModel模型类里重新定义了表‘users’,不然如果你使用 $login=D(‘users‘); 就变成了注册了。

zhugeshiji08月19日

你好,我是thinkphp(3.2.3)的初学者,这两天写了个登录注册的demo,代码如下,但是我的登录页面点击“登录按钮”,没有执行页面的交互(在输入框输入任何内容都没有返回相应的提示信息),所以在这里提问,希望有人能够帮忙解答
下面是登录控制器的代码

  1. public  function login()
  2. {
  3. // 判断提交方式
  4. if(empty($_POST))
  5. {
  6. $this->display();
  7. }
  8. else
  9. {
  10. $code = $_POST["code"];
  11. $verify = new \Think\Verify();
  12. if($verify->check($code,2)) //code是用户输入的值 ,2是验证码检测标示,必须与生成的验证码标示相同才能验证
  13. {
  14. if($_POST["name"]!="" && $_POST["password"]!="")
  15. {
  16. $model = D("thinkpho");
  17. $name = $_POST["name"];
  18. $password = $_POST["password"];
  19. $where = $data[‘name‘];
  20. $attr = $model->where($where)->getField();
  21. //var_dump($attr);pa
  22. if($password==$attr["password"])
  23. {
  24. session("name",$name);   // 跳转页面之前将$name存入session
  25. $this->success("登录成功!","Main");
  26. }
  27. else
  28. {
  29. $this->error("登录失败!");
  30. }
  31. }
  32. else
  33. {
  34. $this->error("用户名或者密码不能为空!");
  35. }
  36. }
  37. else
  38. {
  39. $this->error("验证码不正确!");
  40. }
  41. }
  42. }

复制代码

下面是login视图文件的内容
[code]
<body>
<div class="container">
<form action="__SELF__" method="POST " class="form-signin">
<h2 class="form-signin-heading">Please sign in</h2>
<label for="inputname" class="sr-only">name</label>
<input type="text" name="name" class="form-control" placeholder="name" required autofocus>
<label for="inputPassword" class="sr-only">Password</label>
<input type="password" name="password" class="form-control" placeholder="password" required>
<br>
<div>验证码:<input type="text" name="code" /></div>
<!--src指向方法 -->
<br>
<div><img name="code" type="code" src="__CONTROLLER__/check_verify" alt="验证码" /></div>

<!-- <div class="checkbox">
<label>
<input type="checkbox" value="remember-me"> Remember me
</label>
</div>
-->

<button class="btn btn-lg btn-primary btn-block" type="submit">Sign in</button>
<br>
</form>
</div> <!-- /container -->
</body>
[/code/

时间: 2024-10-09 13:23:05

登陆注册的相关文章

javaweb 登陆注册页面

视图的数据修改,表中也修改引用工具类用<%@ page import=""%> <%@ page import="java.util.Date" %> <%@ page import="java.text.SimpleDateFormat" %> 引入包可以一条一条分着写,也可以在一条内直接用逗号隔开写 <%@ page import="java.util.Date,java.text.Simp

用ajax的同步请求解决登陆注册需要根据服务器返回数据判断是否能提交的问题

最近在写www.doubilaile.com的登陆注册.需要用ajax请求服务器判断用户名是否存在,用户名和密码是否匹配,进而提交数据.碰到的问题是异步请求都能成功返回数据,但是该数据不能作为紧接着的判断的依据.我现在的理解是:异步请求去了服务器端,而本地代码仍在往下执行.服务器数据最终的确会回来,但是本地判断已经执行完毕.所以才会出现密码框单独blur后能提交,而直接submit按钮却要按两次才能提交的问题.将同步改成异步问题解决了.理解是:同步操作会等待服务器数据返回来之后才继续往下执行,所

tkinter 创建登陆注册界面

import tkinter as tk from tkinter import messagebox #设置窗口居中 def window_info(): ws = window.winfo_screenwidth() hs = window.winfo_screenheight() x = (ws / 2) - 200 y = (hs / 2) - 200 print("%d,%d" % (ws, hs)) return x,y #设置登陆窗口属性 window = tk.Tk()

前端开发---登陆注册页面优化

1.本次用到错误提示文字的颜色 http://v3.bootcss.com/css/#forms jquery 教程: http://www.w3school.com.cn/jquery/index.asp 2.工程地址:https://github.com/digitalClass/web_page 网站发布地址: http://115.28.30.25:8029/ 3. 主要工作 优化登陆注册页面显示 因为业务需要, 登陆注册页面被后端给改了, 显示效果如下: 可以看到表单全部乱掉了.打开后

Nodejs连接MySQL&amp;&amp;实现unity中的登陆注册功能

MySQL是一款常用的开源数据库产品,通常也是免费数据库的首选.查了一下NPM列表,发现Nodejs有13库可以访问MySQL,felixge/node-mysql似乎是最受关注项目,我也决定尝试用一下. 要注意名字,"felixge/node-mysql"非"node-mysql",安装目录 1. node-mysql介绍 felixge/node-mysql是一个纯nodejs的用javascript实现的一个MySQL客户端程序.felixge/node-my

Android的SQLiteDataBase小项目,实现user类登陆注册以及student类增删改查

关于SQLiteDataBase这块,大体有两种主要的实现方式,一种是不使用Helper类的方式,此种方式存在一个弊端,即不能oncreate两次,如果重复使用oncreate的button,则会报错,所以为了避免这种错误,在此项目中使用类继承SQLiteOpenHelper的方式进行SQLite3小型数据库的小项目开发,简单的实现登陆注册,以及对特定vo类的增删改查,中间还夹杂了ListView,ArrayAdapter,以及Intent的散知识点. 以下为正文:首先介绍以下我写的项目的框架,

页面点击Button按钮弹出登陆注册框(含短信验证功能)

1 <div class="login-hidd"></div> 2 <div class="login-wrap"> 3 <div class="login-cont"> 4 <img id="login-img-close" src="/views/image/close08.png" alt="登陆" title="&

原生php登陆注册

本以为一个登陆注册功能十来分钟就写好了,没想到thinkPHP用久了,原生的php不会写了 最开始我直接写了类和方法,在前台传递参数给类的login方法(action="index.php/login"),尝试几次发现无法访问,这才意识到,这种方式是mvc模式,原生php不具有 然后,把登陆注册的php代码没有写类和方法直接放到对应的php文件里,前端放在相应的HTML文件里(还是习惯HTML 和php分开来写) 这时候action直接填对应的文件就好了,具体代码如下 login.ph

java web程序 上机考试做一个登陆注册程序

大二期末 java web.用到数据库,jdbc.myeclipse实现用户的注册,登陆 并且不能出现500错误,用户不能重复注册.当用户任意点击时也不能出现500错误! 这里.我只写注册成功的页面.这个不让用户重复注册 当时老师对我各种扣分.可后来.我问他的时候,他说不出来.我不是那个第一个提交作业的学生,可我的分数却比他低,我的功能比他多一个好吧 无所谓啊  谁叫我那么背时,再也不想问了.特别烦躁了 registerOk.jsp <body> <% String name=reque

jquery完成界面无刷新加载登陆注册

昨天公司说官网的登陆注册每次要跳转到另一个界面,能不能做一个简单的,在界面弹出一个框框登陆,我想了想做了这么一个案例,大家来看看成不成 贴上代码,实现了在同一个弹出窗上加载了登陆注册功能!可自由点击!当然样式丑了一些!还请见谅!demo在下面 1这里是html内容 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1