YII2框架中自定義用戶認證模型,完成登陸和注冊操作示例
本文實例講述了YII2框架中自定義用戶認證模型,完成登陸和注冊操作。分享給大家供大家參考,具體如下:
有些時候我們需要自已定義用戶類,操作自已建的用戶表,來完成登陸和注冊功能。
用戶表結(jié)構(gòu)如下,當然可以根據(jù)自已的需要添加或刪除:
CREATE TABLE `tb_user` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '用戶ID', `name` varchar(32) DEFAULT '' COMMENT '用戶名', `pwd` varchar(64) DEFAULT '' COMMENT '密碼', `head_img` varchar(256) DEFAULT '' COMMENT '圖像', `sex` tinyint(1) DEFAULT '0' COMMENT '性別(0:男,1:女)', `age` tinyint(3) DEFAULT '0' COMMENT '年齡', `auth_key` varchar(32) DEFAULT '' COMMENT '認證密鑰', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用戶表';
然后我們在models下創(chuàng)建MyUser.php,代碼如下:
<?php namespace app\models; use YII; use yii\db\ActiveRecord; use yii\web\IdentityInterface; //我們自定義自已的用戶操作模型,需要實現(xiàn)IdentityInterface接口中的全部方法 //我們自定義的模型主要實現(xiàn)的是認證邏輯,而yii\web\User是負責管理用戶認證狀態(tài)的,兩者是有區(qū)別的。 class MyUser extends ActiveRecord implements IdentityInterface { //指定操作的表名 public static function tableName() { return '{{%user}}'; } //通過ID,返回用戶實例 public static function findIdentity($id) { return static::findOne($id); } //通過令牌,返回用戶實例,一般用于無狀態(tài)的restful應(yīng)用 //如果你的應(yīng)用不需要用到,直接留空就行 public static function findIdentityByAccessToken($token, $type = null) { return static::findOne(['access_token' => $token]); } //通過用戶名,返回用戶實例 public static function findByUsername($name) { return static::findOne(['name' => $name]); } //獲取用戶ID public function getId() { return $this->id; } //獲取用戶認證密鑰 public function getAuthKey() { return $this->auth_key; } //生成cookie中的authkey public function generateAuthKey() { $this->auth_key = Yii::$app->security->generateRandomString(32); $this->save(false); } //驗證用戶認證密鑰 public function validateAuthKey($authKey) { return $this->getAuthKey() === $authKey; } //驗證密碼是否正確,當然我們也可以自已定義加密解密方式 public function validatePassword($password) { return Yii::$app->security->validatePassword($password, $this->pwd); } }
創(chuàng)建完我們自已的用戶模型類后,我們需要在配置文件中修改成我們自已的,在config\web.php
'components' => [ // ... 'user' => [ 'identityClass' => 'app\models\MyUser', 'enableAutoLogin' => true, ], ];
然后我們創(chuàng)建一個登陸頁面
<?php use yii\helpers\Url; ?> <!doctype html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>表單提交</title> </head> <body> <form action="<?php echo Url::toRoute('index/login'); ?>" method="post"> 姓名:<input type="text" name="name"><br> 密碼:<input type="password" name="pwd"><br> <input type="submit" value="登陸"> <input name="_csrf" type="hidden" value="<?php echo \Yii::$app->request->csrfToken; ?>"> </form> </body> </html>
然后是處理用戶登陸的,表單模型,在models下創(chuàng)建MyUserLogin.php
<?php namespace app\models; use Yii; use yii\base\Model; class MyUserLogin extends Model { //注意這里要聲明表單中提交過來的變量 public $name; public $pwd; //設(shè)置驗證 public function rules() { return [ [['name', 'pwd'], 'required'], ['pwd', 'validatePassword'], ]; } //驗證密碼 public function validatePassword($attribute, $params) { if (!$this->hasErrors()) { $user = $this->getUser(); if (!$user || !$user->validatePassword($this->pwd)) { $this->addError($attribute, '密碼錯誤'); } } } //登陸處理 public function login() { if ($this->validate()) { $user = $this->getUser(); //監(jiān)聽事件,登陸前,重新生成authkey YII::$app->user->on(\yii\web\User::EVENT_BEFORE_LOGIN, [$user, 'generateAuthKey']); return Yii::$app->user->login($user, 3600 * 24); } return false; } //獲取用戶 public function getUser() { return MyUser::findByUsername($this->name); } }
最后就是我們的控制器代碼
<?php namespace app\controllers; use YII; use yii\web\Controller; use app\models\MyUserLogin; class IndexController extends Controller { public function actionIndex() { //當前用戶的ID var_dump(YII::$app->user->id); //當前用戶是否是游客 var_dump(YII::$app->user->isGuest); } public function actionLogin() { if (YII::$app->request->isPost) { $model = new MyUserLogin(); $model->load(YII::$app->request->post(), ''); if ($model->login()) { echo '登陸成功'; } else { echo '登陸失敗'; } } else { return $this->renderPartial('login'); } } }
演示如下:
更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Yii框架的PHP程序設(shè)計有所幫助。
- Yii2.0框架模型添加/修改/刪除數(shù)據(jù)操作示例
- Yii2.0框架模型多表關(guān)聯(lián)查詢示例
- Yii中Model(模型)的創(chuàng)建及使用方法
- yii框架表單模型使用及以數(shù)組形式提交表單數(shù)據(jù)示例
- PHP YII框架開發(fā)小技巧之模型(models)中rules自定義驗證規(guī)則
- PHP的Yii框架中Model模型的學習教程
- Yii框架數(shù)據(jù)模型的驗證規(guī)則rules()被執(zhí)行的方法
- YII動態(tài)模型(動態(tài)表名)支持分析
- Yii框架表單模型和驗證用法
- Yii模型操作之criteria查找數(shù)據(jù)庫的方法
- Yii數(shù)據(jù)模型中rules類驗證器用法分析
- yii2.0框架多模型操作示例【添加/修改/刪除】
相關(guān)文章
基于PHP+jQuery+MySql實現(xiàn)紅藍(頂踩)投票代碼
當雙方意見不統(tǒng)一的情況下,需要用投票達成協(xié)議,本文通過實例給大家介紹基于PHP+jQuery+MySql實現(xiàn)紅藍(頂踩)投票代碼,需要的朋友可以參考下2015-08-08php版微信公眾平臺之微信網(wǎng)頁登陸授權(quán)示例
這篇文章主要介紹了php版微信公眾平臺之微信網(wǎng)頁登陸授權(quán)的方法,結(jié)合實例形式分析了微信網(wǎng)頁登陸授權(quán)的接口調(diào)用及參數(shù)含義,需要的朋友可以參考下2016-09-09php項目接入xxl-job調(diào)度系統(tǒng)的示例詳解
這篇文章主要介紹了php項目接入xxl-job調(diào)度系統(tǒng)的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12php將數(shù)據(jù)庫中的電話號碼讀取出來并生成圖片
本PHP程序作用是從數(shù)據(jù)庫中讀取出手機號碼或其他數(shù)據(jù)并生成圖片,起到干擾采集防采集的作用。(英文或數(shù)字,如果要支持中文的話需要額外添加字庫)。本代碼為原創(chuàng)代碼。2008-08-08