Yii フレームワークにユーザー認証機能を実装する方法
Yii は、開発プロセスを簡素化する一連のツールとコンポーネントを開発者に提供する強力な PHP フレームワークです。重要な機能の 1 つは、ユーザーがシステムに合法的にログインしているかどうかを判断するユーザー認証です。この記事では、Yii フレームワークにユーザー認証機能を実装する方法とコード例を紹介します。
まず、ユーザー ログイン検証ロジックを処理するユーザー認証モデルを作成する必要があります。 Yii フレームワークでは、yiiwebUser クラスを使用してユーザー認証機能を実装できます。以下はユーザー モデル コードの例です。
namespace appmodels; use yiidbActiveRecord; use yiiwebIdentityInterface; class User extends ActiveRecord implements IdentityInterface { // 用户认证相关的属性和方法 /** * @inheritdoc */ public static function tableName() { return 'user'; // 数据库中存储用户信息的表名 } /** * @inheritdoc */ public static function findIdentity($id) { return static::findOne($id); // 根据用户ID查找用户信息 } /** * @inheritdoc */ public static function findIdentityByAccessToken($token, $type = null) { // 根据用户Token查找用户信息 throw new NotSupportedException('"findIdentityByAccessToken" is not implemented.'); } /** * @inheritdoc */ public function getId() { return $this->id; // 返回用户ID } /** * @inheritdoc */ public function getAuthKey() { return $this->auth_key; // 返回用户认证密钥 } /** * @inheritdoc */ public function validateAuthKey($authKey) { return $this->auth_key === $authKey; // 验证用户认证密钥是否有效 } /** * 根据用户名查找用户信息 * @param $username * @return static */ public static function findByUsername($username) { return static::findOne(['username' => $username]); } /** * 验证用户密码 * @param $password * @return bool */ public function validatePassword($password) { return Yii::$app->security->validatePassword($password, $this->password_hash); } }
上記のコードでは、IdentityInterface インターフェイスを実装し、関連メソッドをオーバーライドしました。これらの方法は主に、ユーザー情報を検索し、ユーザー ID、認証キー、その他の情報に基づいてユーザーの身元を確認するために使用されます。
次に、ユーザーのログイン時に Yii フレームワークが自動的に認証できるように、ユーザー認証コンポーネントを設定する必要があります。 Yii フレームワークでは、ユーザー認証コンポーネントは設定ファイルを通じて定義されます。 config/web.php ファイルを開き、次のコードを追加します。
'components' => [ // ... 'user' => [ 'identityClass' => 'appmodelsUser', 'enableAutoLogin' => true, ], // ... ],
上記のコードでは、「identityClass」を作成したばかりの User クラスに設定し、「enableAutoLogin」を true に設定して、自動ログイン機能。
これで、Yii が提供するユーザー認証機能をコントローラーまたはビューで使用できるようになります。以下は、単純なユーザー ログイン関数のコード例です。
namespace appcontrollers; use Yii; use yiiwebController; use appmodelsLoginForm; class UserController extends Controller { // ... public function actionLogin() { $model = new LoginForm(); if ($model->load(Yii::$app->request->post()) && $model->login()) { // 登录成功跳转到首页 return $this->goHome(); } else { // 显示登录表单 return $this->render('login', [ 'model' => $model, ]); } } // ... }
上記のコードでは、ユーザーのログイン要求を処理するために、UserController コントローラーに actionLogin メソッドを作成しました。 load メソッドを呼び出すことで、ユーザーが送信したログイン フォーム データを LoginForm モデルにロードできます。次に、login メソッドを呼び出してユーザーのログイン認証を実行します。ログインが成功すると、ユーザーはホームページにリダイレクトされ、ログインが失敗すると、ログイン フォーム ビューが表示されます。
最後に、ユーザー ログイン フォーム データの検証と処理を処理するログイン フォーム モデルを作成する必要があります。以下は、単純な LoginForm モデルのコード例です。
namespace appmodels; use Yii; use yiiaseModel; class LoginForm extends Model { public $username; public $password; public $rememberMe = true; private $_user = false; /** * @return array the validation rules. */ public function rules() { return [ [['username', 'password'], 'required'], ['rememberMe', 'boolean'], ['password', 'validatePassword'], ]; } /** * Validates the password. * This method serves as the inline validation for password. * * @param string $attribute the attribute currently being validated * @param array $params the additional name-value pairs given in the rule */ public function validatePassword($attribute, $params) { if (!$this->hasErrors()) { $user = $this->getUser(); if (!$user || !$user->validatePassword($this->password)) { $this->addError($attribute, 'Incorrect username or password.'); } } } /** * Logs in a user using the provided username and password. * @return bool whether the user is logged in successfully */ public function login() { if ($this->validate()) { return Yii::$app->user->login($this->getUser(), $this->rememberMe ? 3600*24*30 : 0); } else { return false; } } /** * Finds user by [[username]] * * @return User|null */ protected function getUser() { if ($this->_user === false) { $this->_user = User::findByUsername($this->username); } return $this->_user; } }
上記のコードでは、LoginForm モデルを作成し、いくつかのプロパティとメソッドを定義します。 rules メソッドはログイン フォームの検証ルールを定義し、validatePassword メソッドはユーザーが入力したパスワードを検証するために使用され、login メソッドはユーザー ログインの論理処理に使用され、getUser メソッドはユーザー情報に基づいてユーザー情報を検索するために使用されます。ユーザー名。
これまでのところ、Yii フレームワークにユーザー認証機能を実装することに成功しました。ユーザーは、UserController の actionLogin メソッドにアクセスすることでログインでき、ログインに成功すると、指定されたページにジャンプします。
概要
この記事では、Yii フレームワークにユーザー認証機能を実装する方法を紹介します。ユーザー認証モデルを作成し、ユーザー認証コンポーネントを設定し、ログイン機能を実装し、ログインフォームモデルを作成することで、Yii フレームワークにユーザー認証機能を簡単に実装できます。もちろん、ユーザー認証機能は、RBAC 権限制御やその他の機能と組み合わせて、特定のビジネス ニーズに合わせてさらに拡張およびカスタマイズすることもできます。
以上がYiiフレームワークにユーザー認証機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。