ThinkPHP登陆注册

Posted 一阙梅曲香素笺

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ThinkPHP登陆注册相关的知识,希望对你有一定的参考价值。

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.  
  4. Source Server         : 本地连接
  5. Source Server Version : 50617
  6. Source Host           : localhost:3306
  7. Source Database       : crm
  8.  
  9. Target Server Type    : MYSQL
  10. Target Server Version : 50617
  11. File Encoding         : 65001
  12.  
  13. Date: 2015-06-29 23:55:28
  14. */
  15.  
  16. SET FOREIGN_KEY_CHECKS=0;
  17.  
  18.  -- ----------------------------
  19.  -- Table structure for think_users
  20.  -- ----------------------------
  21. DROP TABLE IF EXISTS `think_users`;
  22. CREATE TABLE `think_users` (
  23.   `userid` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘用户id‘,
  24.   `companyid` mediumint(8) unsigned NOT NULL COMMENT ‘公司id‘,
  25.   `pid` mediumint(8) NOT NULL COMMENT ‘父id‘,
  26.   `username` char(20) NOT NULL DEFAULT ‘‘ COMMENT ‘用户名‘,
  27.   `password` char(32) NOT NULL DEFAULT ‘‘ COMMENT ‘密码‘,
  28.   `nickname` char(20) NOT NULL DEFAULT ‘‘ COMMENT ‘昵称‘,
  29.   `regdate` int(10) unsigned NOT NULL COMMENT ‘注册时间‘,
  30.   `lastdate` int(10) unsigned NOT NULL COMMENT ‘最后一次登录时间‘,
  31.   `regip` char(15) NOT NULL DEFAULT ‘‘ COMMENT ‘注册ip‘,
  32.   `lastip` char(15) NOT NULL DEFAULT ‘‘ COMMENT ‘最后一次登录ip‘,
  33.   `loginnum` smallint(5) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘登录次数‘,
  34.   `email` char(32) NOT NULL DEFAULT ‘‘ COMMENT ‘邮箱‘,
  35.   `mobile` char(11) NOT NULL DEFAULT ‘‘ COMMENT ‘手机号码‘,
  36.   `islock` tinyint(1) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘是否锁定‘,
  37.   `vip` tinyint(1) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘是否会员‘,
  38.   `overduedate` int(10) unsigned NOT NULL COMMENT ‘账户过期时间‘,
  39.   `status` tinyint(1) unsigned NOT NULL DEFAULT ‘0‘ COMMENT ‘状态-用于软删除‘,
  40.   PRIMARY KEY (`userid`),
  41.   UNIQUE KEY `username` (`username`) USING BTREE,
  42.   KEY `email` (`email`) USING BTREE
  43.  ) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
复制代码
创建模型(用于自动验证, 自动完成) :
  1. namespace Home\Model;
  2.  use Think\Model;
  3.  
  4.  class UsersModel extends Model {
  5.     /**
  6.      * 自动验证
  7.      * self::EXISTS_VALIDATE 或者0 存在字段就验证(默认)
  8.      * self::MUST_VALIDATE 或者1 必须验证
  9.      * self::VALUE_VALIDATE或者2 值不为空的时候验证
  10.      */
  11.     protected $_validate = array(
  12.         array(‘nickname‘, ‘require‘, ‘昵称不能为空!‘), //默认情况下用正则进行验证
  13.         array(‘username‘, ‘require‘, ‘用户名不能为空!‘), //默认情况下用正则进行验证
  14.         array(‘username‘, ‘‘, ‘该用户名已被注册!‘, 0, ‘unique‘, 1), // 在新增的时候验证name字段是否唯一
  15.         array(‘email‘, ‘‘, ‘该邮箱已被占用‘, 0, ‘unique‘, 1), // 新增的时候email字段是否唯一
  16.         array(‘mobile‘, ‘‘, ‘该手机号码已被占用‘, 0, ‘unique‘, 1), // 新增的时候mobile字段是否唯一
  17.         // 正则验证密码 [需包含字母数字以及@*#中的一种,长度为6-22位]
  18.         array(‘password‘, ‘/^([[email protected]*#]{6,22})$/‘, ‘密码格式不正确,请重新输入!‘, 0),
  19.         array(‘repassword‘, ‘password‘, ‘确认密码不正确‘, 0, ‘confirm‘), // 验证确认密码是否和密码一致
  20.         array(‘email‘, ‘email‘, ‘邮箱格式不正确‘), // 内置正则验证邮箱格式
  21.         array(‘mobile‘, ‘/^1[34578]\d{9}$/‘, ‘手机号码格式不正确‘, 0), // 正则表达式验证手机号码
  22.         array(‘verify‘, ‘verify_check‘, ‘验证码错误‘, 0, ‘function‘), // 判断验证码是否正确
  23.         //array(‘agree‘, ‘is_agree‘, ‘请先同意网站安全协议!‘, 1, ‘callback‘), // 判断是否勾选网站安全协议
  24.         array(‘agree‘, ‘require‘, ‘请先同意网站安全协议!‘, 1), // 判断是否勾选网站安全协议
  25.     );
  26.  
  27.     /**
  28.      * 自动完成
  29.      */
  30.     protected $_auto = array (
  31.         array(‘password‘, ‘md5‘, 3, ‘function‘) , // 对password字段在新增和编辑的时候使md5函数处理
  32.         array(‘regdate‘, ‘time‘, 1, ‘function‘), // 对regdate字段在新增的时候写入当前时间戳
  33.         array(‘regip‘, ‘get_client_ip‘, 1, ‘function‘), // 对regip字段在新增的时候写入当前注册ip地址
  34.     );
  35.  
  36.     /**
  37.      * 判断是否同意网站安全管理协议
  38.      * @return bool
  39.      */
  40.     protected function is_agree()
  41.     {
  42.         // 获取POST数据
  43.         $agree = I(‘post.agree‘, 0, ‘intval‘);
  44.  
  45.         // 验证
  46.         if ($agree) {
  47.             return true;
  48.         } else {
  49.             return false;
  50.         }
  51.     }
复制代码
登录注册 :
  1. namespace Home\Controller;
  2.  use Think\Controller;
  3.  
  4.  /**
  5.  * Class LoginController
  6.  * @package Home\Controller
  7.  */
  8.  class LoginController extends Controller {
  9.     /**
  10.      * 用户登录
  11.      */
  12.     public function login()
  13.     {
  14.         // 判断提交方式
  15.         if (IS_POST) {
  16.             // 实例化Login对象
  17.             $login = D(‘login‘);
  18.  
  19.             // 自动验证 创建数据集
  20.             if (!$data = $login->create()) {
  21.                 // 防止输出中文乱码
  22.                 header("Content-type: text/html; charset=utf-8");
  23.                 exit($login->getError());
  24.             }
  25.  
  26.             // 组合查询条件
  27.             $where = array();
  28.             $where[‘username‘] = $data[‘username‘];
  29.             $result = $login->where($where)->field(‘userid,username,nickname,password,lastdate,lastip‘)->find();
  30.  
  31.             // 验证用户名 对比 密码
  32.             if ($result && $result[‘password‘] == $result[‘password‘]) {
  33.                 // 存储session
  34.                 session(‘uid‘, $result[‘userid‘]);          // 当前用户id
  35.                 session(‘nickname‘, $result[‘nickname‘]);   // 当前用户昵称
  36.                 session(‘username‘, $result[‘username‘]);   // 当前用户名
  37.                 session(‘lastdate‘, $result[‘lastdate‘]);   // 上一次登录时间
  38.                 session(‘lastip‘, $result[‘lastip‘]);       // 上一次登录ip
  39.  
  40.                 // 更新用户登录信息
  41.                 $where[‘userid‘] = session(‘uid‘);
  42.                 M(‘users‘)->where($where)->setInc(‘loginnum‘);   // 登录次数加 1
  43.                 M(‘users‘)->where($where)->save($data);   // 更新登录时间和登录ip
  44.  
  45.                 $this->success(‘登录成功,正跳转至系统首页...‘, U(‘Index/index‘));
  46.             } else {
  47.                 $this->error(‘登录失败,用户名或密码不正确!‘);
  48.             }
  49.         } else {
  50.             $this->display();
  51.         }
  52.     }
  53.  
  54.     /**
  55.      * 用户注册
  56.      */
  57.     public function register()
  58.     {
  59.         // 判断提交方式 做不同处理
  60.         if (IS_POST) {
  61.             // 实例化User对象
  62.             $user = D(‘users‘);
  63.  
  64.             // 自动验证 创建数据集
  65.             if (!$data = $user->create()) {
  66.                 // 防止输出中文乱码
  67.                 header("Content-type: text/html; charset=utf-8");
  68.                 exit($user->getError());
  69.             }
  70.  
  71.             //插入数据库
  72.             if ($id = $user->add($data)) {
  73.                 /* 直接注册用户为超级管理员,子用户采用邀请注册的模式,
  74.                    遂设置公司id等于注册用户id,便于管理公司用户*/
  75.                 $user->where("userid = $id")->setField(‘companyid‘, $id);
  76.                 $this->success(‘注册成功‘, U(‘Index/index‘), 2);
  77.             } else {
  78.                 $this->error(‘注册失败‘);
  79.             }
  80.         } else {
  81.             $this->display();
  82.         }
  83.     }
  84.  
  85.     /**
  86.      * 用户注销
  87.      */
  88.     public function logout()
  89.     {
  90.         // 清楚所有session
  91.         session(null);
  92.         redirect(U(‘Login/login‘), 2, ‘正在退出登录...‘);
  93.     }
  94.  
  95.     /**
  96.      * 验证码
  97.      */
  98.     public function verify()
  99.     {
  100.         // 实例化Verify对象
  101.         $verify = new \Think\Verify();
  102.  
  103.         // 配置验证码参数
  104.         $verify->fontSize = 14;     // 验证码字体大小
  105.         $verify->length = 4;        // 验证码位数
  106.         $verify->imageH = 34;       // 验证码高度
  107.         $verify->useImgBg = true;   // 开启验证码背景
  108.         $verify->useNoise = false;  // 关闭验证码干扰杂点
  109.         $verify->entry();
  110.     }
  111.  }
复制代码
登录模版 :
  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.  
  2.  public  function login()
  3.    
  4.     {
  5.         // 判断提交方式
  6.         if(empty($_POST))
  7.         {
  8.             $this->display();    
  9.         }    
  10.         else
  11.         {
  12.             $code = $_POST["code"];
  13.              $verify = new \Think\Verify();
  14.            if($verify->check($code,2)) //code是用户输入的值 ,2是验证码检测标示,必须与生成的验证码标示相同才能验证
  15.             {
  16.                 if($_POST["name"]!="" && $_POST["password"]!="")
  17.                 {
  18.                     $model = D("thinkpho");
  19.                     $name = $_POST["name"];    
  20.                     $password = $_POST["password"];
  21.                     $where = $data[‘name‘];
  22.                     $attr = $model->where($where)->getField();
  23.                     //var_dump($attr);pa
  24.                     if($password==$attr["password"])
  25.                     {
  26.                         session("name",$name);   // 跳转页面之前将$name存入session                  
  27.                         $this->success("登录成功!","Main");                        
  28.                     }
  29.                     else
  30.                     {
  31.                         $this->error("登录失败!");    
  32.                     }
  33.                 }
  34.                 else
  35.                     {
  36.                         $this->error("用户名或者密码不能为空!");    
  37.                     }
  38.             }
  39.             else
  40.             {
  41.                 $this->error("验证码不正确!");    
  42.             }
  43.         }        
  44.     }
  45.  
复制代码

下面是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/














































以上是关于ThinkPHP登陆注册的主要内容,如果未能解决你的问题,请参考以下文章

登陆注册

ThinkPHP邮箱验证

练习项目thinkphp用户注册

thinkphp 怎么做登录验证

小程序+thinkphp5 用户登陆,返回第三方session3rd

thinkphp开发微信小程序后台流程