Am在yii2基本项目中实施身份验证 登录操作似乎正常
public function actionLogin()
{
$this->layout = "login-layout";
if (!Yii::$app->user->isGuest) {
return $this->goHome();
}
$model = new LoginForm();
if ($model->load(Yii::$app->request->post()) && $model->login()) {
if (Yii::$app->user->isGuest) {
var_dump("guest"); die();
} else {
var_dump("This is user"); die();
}
}
$model->password = '';
return $this->render('login', [
'model' => $model,
]);
}
我已在config.php中按要求配置了 ,如下所示
'as beforeRequest' => [
'class' => 'yii\filters\AccessControl',
'rules' => [
[
'allow' => true,
'actions' => ['login'],
],
[
'allow' => true,
'roles' => ['@'],
],
],
'denyCallback' => function () {
return Yii::$app->response->redirect(['site/login']);
},
],
我的问题是即使用户成功通过身份验证,我仍然无法访问其他页面,并一直重定向到登录页面 请帮助我解决这个问题。
答案 0 :(得分:1)
最后,经过几个小时的调试,我得以解决此问题。问题是由我的用户模型中的 findIdentity 方法引起的,因为我正在创建它以返回null,如下所示:
public static function findIdentity($MemberId) {
$user = self::find();
return ;//static($user);
}
所以我将其更改为
public static function findIdentity($MemberId) {
$user = self::find()->where(['MemberId' => $MemberId])->one();
return $user;
}
现在,它可以正常工作,因此问题不在 beforeRequest 中,而是应用程序未找到实际用户。