Yii2 基本バージョンのログインは Yii::$app->user->login($user) を使用します。エラーが発生します。
Yii2 basic
版登录使用Yii::$app->user->login($user);
出现错误Array to string conversion
MyAuthenticationController.php
<code><?php namespace app\controllers; use Yii; use yii\web\Controller; use app\models\User; class MyAuthenticationController extends Controller { public function actionIndex() { echo 'login success'; exit; } public function actionLogin() { $error = null; $username = Yii::$app->request->post('username',null); $password = Yii::$app->request->post('password',null); $user = User::findOne(['username'=>$username]); if(($username!=null)&&($password!=null)) { if($user!=null){ if($user->validatePassword($password)){ $this->redirect(['index']);//这里可以实现重定向 // Yii::$app->user->login($user);这是源代码,但是会出现“Array to string conversion”的错误,暂时还没有解决,所以使用上面的重定向代码来转向指定登录成功的页面 }else{ $error = 'Password validation failed'; } }else{ $error = 'User not found'; } } return $this->render('login',['error'=>$error]); } public function actionLogout() { Yii::$app->user->logout(); return $this->redirect(['login']); } }</code>
app\models\User.php
<code><?php namespace app\models; use Yii; use yii\base\NotSupportedException; use yii\db\ActiveRecord; use yii\web\IdentityInterface; class User extends ActiveRecord implements IdentityInterface { 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) { return static::findOne(['access_token'=>$token]); } /** * Finds user by username * * @param string $username * @return static|null */ public static function findByUsername($username) { return static::findOne(['username'=>$username]); } /** * @inheritdoc */ public function getId() { return $this->PrimaryKey(); } /** * @inheritdoc */ public function getAuthKey() { return $this->auth_Key; } /** * @inheritdoc */ public function validateAuthKey($authKey) { return $this->getAuthKey() === $authKey; } /** * Validates password * * @param string $password password to validate * @return boolean if password provided is valid for current user */ public function validatePassword($password) { return Yii::$app->security->validatePassword($password,$this->password_hash); } public function generateAuthKey() { $this->auth_key = Yii::$app->security->generateRandomKey(); } public function beforeSave($insert) { if(parent::beforeSave($insert)){ if($this->isNewRecord){ $this->auth_key = \Yii::$app->security->generateRandomString(); } return true; } return false; } }</code>
views\my-authentication\login.php
<code><?php use \yii\bootstrap\ActiveForm; use \yii\helpers\Html; use \yii\bootstrap\Alert; ?> <?php if($error!=null){ echo Alert::widget(['options'=>['class'=>'alert-danger'],'body'=>$error]); }; ?> <?php if(Yii::$app->user->isGuest) { ?> <?php ActiveForm::begin() ?> <div class="form-group"> <?php echo Html::label('Username','username'); ?> <?php echo Html::textInput('username','',['class'=>'form-control']);?> </div> <div class="form-group"> <?php echo Html::label('Password','password'); ?> <?php echo Html::passwordInput('password','',['class'=>'form-control']); ?> </div> <?php echo Html::submitButton('Login',['class'=>'btn btn-primary']); ?> <?php ActiveForm::end(); ?> <?php } else {?> <h2>You are authentication!</h2> <br/><br/> <?php echo Html::a('logout',['my-authentication/logout'],['class'=>'btn btn-warning']); ?> <?php } ?></code>
SQL
<code>-- -- 表的结构 `user` -- CREATE TABLE IF NOT EXISTS `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(255) NOT NULL, `auth_key` varchar(32) NOT NULL, `password_hash` varchar(255) NOT NULL, `access_token` varchar(100) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ; -- -- 转存表中的数据 `user` -- INSERT INTO `user` (`id`, `username`, `auth_key`, `password_hash`, `access_token`) VALUES (1, 'foo', '', '$2a$12$hL0rmIMjxhLqI.xr7jD1FugNWEgZNh62HuJj5.y34XBUfBWB4cppW', NULL);</code>
用户名是foo
,密码是foopassword
,登录后在Yii::$app->user->login($user);
时出现错误,
回复内容:
Yii2 basic
版登录使用Yii::$app->user->login($user);
出现错误Array to string conversion
MyAuthenticationController.php
<code><?php namespace app\controllers; use Yii; use yii\web\Controller; use app\models\User; class MyAuthenticationController extends Controller { public function actionIndex() { echo 'login success'; exit; } public function actionLogin() { $error = null; $username = Yii::$app->request->post('username',null); $password = Yii::$app->request->post('password',null); $user = User::findOne(['username'=>$username]); if(($username!=null)&&($password!=null)) { if($user!=null){ if($user->validatePassword($password)){ $this->redirect(['index']);//这里可以实现重定向 // Yii::$app->user->login($user);这是源代码,但是会出现“Array to string conversion”的错误,暂时还没有解决,所以使用上面的重定向代码来转向指定登录成功的页面 }else{ $error = 'Password validation failed'; } }else{ $error = 'User not found'; } } return $this->render('login',['error'=>$error]); } public function actionLogout() { Yii::$app->user->logout(); return $this->redirect(['login']); } }</code>
app\models\User.php
<code><?php namespace app\models; use Yii; use yii\base\NotSupportedException; use yii\db\ActiveRecord; use yii\web\IdentityInterface; class User extends ActiveRecord implements IdentityInterface { 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) { return static::findOne(['access_token'=>$token]); } /** * Finds user by username * * @param string $username * @return static|null */ public static function findByUsername($username) { return static::findOne(['username'=>$username]); } /** * @inheritdoc */ public function getId() { return $this->PrimaryKey(); } /** * @inheritdoc */ public function getAuthKey() { return $this->auth_Key; } /** * @inheritdoc */ public function validateAuthKey($authKey) { return $this->getAuthKey() === $authKey; } /** * Validates password * * @param string $password password to validate * @return boolean if password provided is valid for current user */ public function validatePassword($password) { return Yii::$app->security->validatePassword($password,$this->password_hash); } public function generateAuthKey() { $this->auth_key = Yii::$app->security->generateRandomKey(); } public function beforeSave($insert) { if(parent::beforeSave($insert)){ if($this->isNewRecord){ $this->auth_key = \Yii::$app->security->generateRandomString(); } return true; } return false; } }</code>
views\my-authentication\login.php
<code><?php use \yii\bootstrap\ActiveForm; use \yii\helpers\Html; use \yii\bootstrap\Alert; ?> <?php if($error!=null){ echo Alert::widget(['options'=>['class'=>'alert-danger'],'body'=>$error]); }; ?> <?php if(Yii::$app->user->isGuest) { ?> <?php ActiveForm::begin() ?> <div class="form-group"> <?php echo Html::label('Username','username'); ?> <?php echo Html::textInput('username','',['class'=>'form-control']);?> </div> <div class="form-group"> <?php echo Html::label('Password','password'); ?> <?php echo Html::passwordInput('password','',['class'=>'form-control']); ?> </div> <?php echo Html::submitButton('Login',['class'=>'btn btn-primary']); ?> <?php ActiveForm::end(); ?> <?php } else {?> <h2>You are authentication!</h2> <br/><br/> <?php echo Html::a('logout',['my-authentication/logout'],['class'=>'btn btn-warning']); ?> <?php } ?></code>
SQL
<code>-- -- 表的结构 `user` -- CREATE TABLE IF NOT EXISTS `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(255) NOT NULL, `auth_key` varchar(32) NOT NULL, `password_hash` varchar(255) NOT NULL, `access_token` varchar(100) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=2 ; -- -- 转存表中的数据 `user` -- INSERT INTO `user` (`id`, `username`, `auth_key`, `password_hash`, `access_token`) VALUES (1, 'foo', '', '$2a$12$hL0rmIMjxhLqI.xr7jD1FugNWEgZNh62HuJj5.y34XBUfBWB4cppW', NULL);</code>
用户名是foo
,密码是foopassword
,登录后在Yii::$app->user->login($user);
时出现错误,
<code>public function getId() { return $this->getPrimaryKey(); }</code>
不是 PrimaryKey

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

CakePHP はオープンソースの MVC フレームワークです。これにより、アプリケーションの開発、展開、保守がはるかに簡単になります。 CakePHP には、最も一般的なタスクの過負荷を軽減するためのライブラリが多数あります。

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます
