Yii2框架实现注册和登录教程


Posted in PHP onSeptember 30, 2016

注册

在advanced模板中,进入frontend/index.php?r=site%2Fsignup页面,可以看到框架的注册页面

Yii2框架实现注册和登录教程

填写完Username、Email和Password后点击Signup后,如果格式不对,frontend/models/SignuForm中的rules()函数会进行初步验证,所有格式正确后,数据传输到 frontend/controllers /SiteController中的 actionSignup()函数中,函数加载用户输入的注册信息,在frontend/models/SignupForm中的signup()函数,

以下引用的文字为解释函数中的具体细节,不阅读不影响整体,因为没有折叠文字功能,故采用引用的方法,下同

if (!$this->validate()) {
  return null;
}

signup() 函数首先调用 yii2/base/Model中的validate() 函数进行验证
第一步,清除使用frontend/models/SignuForm中的rules()函数在用户输入时的错误信息

if ($clearErrors) {
  $this->clearErrors();
}

第二步,beforeValidate()函数触发beforeValidate事件并返回true
第三步,设置scenario,默认是default
第四步,因为这里的$attributeNames为null,

$attributeNames = $this->activeAttributes();

执行后返回

array(3) { [0]=> string(8) "username" [1]=> string(5) "email" [2]=> string(8) >"password" }

第五步,$this->getActiveValidators()会得到frontend/models/SignuForm中的rules()中11条验证规则给validateAttributes()进行验证

第六步,执行afterValidate()函数触发afterValidate事件

最后 如果所有验证都通过,$this->hasErrors()为false,所以函数最后返回true

我们看一下数据表user的字段

Yii2框架实现注册和登录教程

用户输入了username、password和email,Yii2框架是如何生成其他的字段的呢,先看password_hash,在SignupFrom中的signup函数中的密码生成是setPassword函数,该函数在common/models/User中,setPassword函数调用了yii2/base/Security中的每一条规则generatePasswordHash函数。

if (function_exists('password_hash')) {
  /** @noinspection PhpUndefinedConstantInspection */
  return password_hash($password, PASSWORD_DEFAULT, ['cost' => $cost]);
}

如果有,就使用password_hash函数进行加密,如果PHP没有password_hash函数,就使用crypt函数加密,初步判断应该是为了兼容PHP低于5.5的版本,毕竟大于5.5的版本才开始有password_hash函数

common/models/User的signup()函数在对password加密后,就会继续生成一个auth key,auth key是当用户在登录的时候点击 remember me的时候的验证信息,

auth key生成的方法也是在yii2/base/Security中的generateRandomString,generateRandomString调用generateRandomKey函数,如果你的PHP版本为是5.2~5.6或者是7,那就是用random_bytes生成一个32个字节的字符串,如果不是,当你用的系统时windows并且安装了OpenSSL,就会调用openssl_random_pseudo_bytes函数生成,如果你未安装OpenSSL,就会使用mcrypt_create_iv生成。

如果你使用的系统不是windows,就需要调用/dev/urandom,FreeBSD系统特殊,会调用/dev/random,然后调用stream_set_read_buffer方法生成8字节的字符文件,生成后,通过fread函数读取该文件中的32个字节,然后返回该数据。
password_reset_token在用户注册的时候是为空的,当用户忘记密码在登录页面点击reset it 后生成的,用来给用法发送邮件后重置密码时进行验证。

status 在common/models/User中定义的

const STATUS_DELETED = 0;
const STATUS_ACTIVE = 10;

用户注册时rules中的status默认为为10,
created_time和updated_time也是在common/models/User中的behaviors()函数中生成

用户的数据验证合格,加上框架生成的数据,然后存储进数据的user表里。

登录

关于frontend/controllers/SiteController中的actionSignup()中的

if (Yii::$app->getUser()->login($user)) {
  return $this->goHome();
}

就是用户注册后,这时该用户的数据已经写入数据库了,开始登录的过程了

登录的过程在yii2/web/User里的login()函数中

第一步,执行beforeLogin()函数触发beforeLogin事件
第二步,switchIdentity()函数把个人信息换成当前用户的信息,把所有的cookie都销毁,然后把当前用户的信息都存入到session和cookie中
第三步,获取当前用户的id和用户登录的ip,并写入到log中
第四步,执行afterLogin()函数触发afterLogin事件

最后 返回true

判断登录成功后,return $this->goHome();跳转到主页。

PHP 相关文章推荐
destoon设置自定义搜索的方法
Jun 21 PHP
php+xml编程之SimpleXML的应用实例
Jan 24 PHP
PHP实现多维数组转字符串和多维数组转一维数组的方法
Aug 08 PHP
Yii中Model(模型)的创建及使用方法
Dec 28 PHP
Zend Framework框架之Zend_Mail实现发送Email邮件验证功能及解决标题乱码的方法
Mar 21 PHP
Zend Framework数据库操作方法实例总结
Dec 11 PHP
使用PHP连接多种数据库的实现代码(mysql,access,sqlserver,Oracle)
Dec 21 PHP
PHP面向对象学习之parent::关键字
Jan 18 PHP
php正则判断是否为合法身份证号的方法
Mar 16 PHP
CI框架(CodeIgniter)操作redis的方法详解
Jan 25 PHP
TP(thinkPHP)框架多层控制器和多级控制器的使用示例
Jun 13 PHP
php文件包含的几种方式总结
Sep 19 PHP
php多线程并发实现方法
Sep 30 #PHP
PHP7安装Redis扩展教程【Linux与Windows平台】
Sep 30 #PHP
分享PHP-pcntl 实现多进程代码
Sep 30 #PHP
PHP编写daemon process详解及实例代码
Sep 30 #PHP
PHP 极验验证码实例讲解
Sep 29 #PHP
php自定义函数转换html标签示例
Sep 29 #PHP
php自定义函数实现汉字转换utf8编码的方法
Sep 29 #PHP
You might like
php5中date()得出的时间为什么不是当前时间的解决方法
2008/06/30 PHP
php中使用preg_replace函数匹配图片并加上链接的方法
2013/02/06 PHP
探讨多键值cookie(php中cookie存取数组)的详解
2013/06/06 PHP
神盾加密解密教程(二)PHP 神盾解密
2014/06/08 PHP
Laravel中Trait的用法实例详解
2016/03/16 PHP
总结对比php中的多种序列化
2016/08/28 PHP
网页里控制图片大小的相关代码
2006/06/13 Javascript
Javascript 获取LI里的内容
2008/12/17 Javascript
jquery checkbox,radio是否选中的判断代码
2010/03/20 Javascript
简介JavaScript中Boolean.toSource()方法的使用
2015/06/05 Javascript
页面间固定参数,通过cookie传值的实现方法
2017/05/31 Javascript
javascript实现最长公共子序列实例代码
2018/02/05 Javascript
关于JavaScript中高阶函数的魅力详解
2018/09/07 Javascript
JavaScript中的"=、==、==="区别讲解
2019/01/22 Javascript
Vue2.4+新增属性.sync、$attrs、$listeners的具体使用
2020/03/08 Javascript
js+canvas实现刮刮奖功能
2020/09/13 Javascript
html5以及jQuery实现本地图片上传前的预览代码实例讲解
2021/03/01 jQuery
python自动格式化json文件的方法
2015/03/11 Python
python实现简单socket程序在两台电脑之间传输消息的方法
2015/03/13 Python
Python selenium 父子、兄弟、相邻节点定位方式详解
2016/09/15 Python
python常见的格式化输出小结
2016/12/15 Python
Python实现文件内容批量追加的方法示例
2017/08/29 Python
基于DATAFRAME中元素的读取与修改方法
2018/06/08 Python
Python判断是否json是否包含一个key的方法
2018/12/31 Python
利用python脚本如何简化jar操作命令
2019/02/24 Python
tensorflow实现残差网络方式(mnist数据集)
2020/05/26 Python
python 制作网站筛选工具(附源码)
2021/01/21 Python
THE OUTNET美国官网:国际设计师品牌折扣网站
2017/03/07 全球购物
印度尼西亚最完整和最大的在线药房网站:Farmaku.com
2019/11/23 全球购物
abstract class和interface有什么区别?
2012/01/03 面试题
英语演讲稿范文
2014/01/03 职场文书
会计专业自我评价
2014/02/12 职场文书
师德自我剖析材料范文
2014/10/06 职场文书
预备党员期盼十八届四中全会召开思想汇报
2014/10/17 职场文书
JUnit5常用注解的使用
2021/07/02 Java/Android
Python使用pandas导入csv文件内容的示例代码
2022/12/24 Python