Maison  >  Article  >  cadre php  >  Comment se connecter à yii

Comment se connecter à yii

尚
original
2019-12-31 14:56:201917parcourir

Comment se connecter à yii

Exemple de méthode de connexion yii :

1. LoginForm.php

Module de connexion utilisateur, ce qui est soumis est le nom d'utilisateur et le mot de passe, donc nous vous Vous devez d'abord créer un modèle pour traiter spécifiquement les données soumises par les utilisateurs, alors créez d'abord un nouveau LoginForm.php. Voici le code :

<?php
 
namespace app\modules\backend\models;
 
use Yii;
use yii\base\Model;
 
/**
 * LoginForm is the model behind the login form.
 */
class LoginForm extends Model
{
    public $username;
    public $password;
    public $rememberMe = true;
 
    private $_user = false;
 
 
    /**
     * @return array the validation rules.
     */
    public function rules()<span style="white-space:pre">		</span>//①
    {
        return [
            // username and password are both required
            [[&#39;username&#39;, &#39;password&#39;], &#39;required&#39;,&#39;message&#39;=>""],
            // rememberMe must be a boolean value
            [&#39;rememberMe&#39;, &#39;boolean&#39;],
            // password is validated by validatePassword()
            [&#39;password&#39;, &#39;validatePassword&#39;],
        ];
    }
 
    /**
     * 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, &#39;Incorrect username or password.&#39;);
            }
        }
    }
 
    /**
     * Logs in a user using the provided username and password.
     * @return boolean whether the user is logged in successfully
     */
    public function login()
    {
        if ($this->validate()) {
            if($this->rememberMe)
            {
                $this->_user->generateAuthKey();//③
            }
            return Yii::$app->user->login($this->getUser(), $this->rememberMe ? 3600*24*30 : 0);
        }
        return false;
    }
 
    /**
     * Finds user by [[username]]
     *
     * @return User|null
     */
    public function getUser()
    {
        if ($this->_user === false) {
            $this->_user = User::findByUsername($this->username); //②
        }
 
        return $this->_user;
    }
}

Ce modèle est modifié en fonction du LoginForm fourni avec le modèle de base. La plupart du code a Remarque, faites attention au code suivant ici :

Le numéro de code ① est la règle des règles. Les règles définissent les règles pour les données remplies, vérifiez si les données remplies. est vide, si elle est conforme au format, etc., parmi lesquelles il y en a une La colonne est password, et la règle correspondante est validatePassword, qui appellera automatiquement la méthode validatePassword() de la classe actuelle. Faites attention à la distinguer. la méthode correspondant à la classe User ci-dessous.

Le numéro de code ② appelle la méthode findByUsername dans la classe User. Cette classe User sera écrite ci-dessous, principalement pour renvoyer une instance de classe AR à comparer avec les données LoginForm actuelles.

Le numéro de code ③ ne sera pas mentionné ici pour l'instant. Nous le mentionnerons plus tard lorsque nous parlerons de connexion par cookie.

2. User.php

(1) Classe ActiveRecord

Après avoir rempli le LoginForm, il nous manque encore quelque chose. Après avoir reçu les données de l'utilisateur, nous en avons encore besoin. à La base de données extrait les données correspondantes à des fins de comparaison, nous devons donc compléter ensuite une classe pour les données obtenues à partir de la base de données - la classe AR, le nom complet est ActiveRecord, la classe d'enregistrement active, qui est pratique pour rechercher des données . Tant que le nom de la classe et la table de données sont identiques, alors il peut obtenir des données de cette table de données, par exemple :

<?php
namespace app\modules\backend\models;
use yii\db\ActiveRecord;
 
class User extends ActiveRecord{       } ?>

Vous pouvez également ajouter vous-même le nom de la table renvoyé, remplacez simplement la méthode suivante dans cette classe :

public static function tableName(){
		return &#39;user&#39;;
	}

(2) Interface IdentityInterface

De manière générale, pour rechercher des données dans la base de données, il vous suffit d'hériter de la classe AR. Cependant, la nôtre l'est. un modèle de connexion utilisateur, et le noyau est la vérification, il est donc naturel d'implémenter la fonction de vérification principale, tout comme validatePassword mentionné dans le modèle LoginForm, la logique de vérification réelle est complétée dans le modèle utilisateur actuel. De manière générale, pour implémenter l'interface IdentityInterface, vous devez implémenter les méthodes suivantes :

    public static function findIdentity($id);  //①
 
    public static function findIdentityByAccessToken($token, $type = null);   //②
 
    public function getId();    //③
 
    public function getAuthKey();   //④
 
    public function validateAuthKey($authKey);    //⑤

①findIdentity : Rechercher les données correspondant à la table de données en fonction de l'identifiant

②findIdentityByAccessToken consiste à trouver le correspondant données basées sur AccessToken (mentionné ci-dessus) Data et AccessToken, nous avons également ce champ dans la table de données, alors à quoi sert-il ? En fait, AccessToken n'est pas très utile dans notre modèle de connexion utilisateur actuel. Il est spécialement utilisé pour la vérification de connexion Resetful. Les détails peuvent être trouvés sur Baidu, je ne l'expliquerai pas ici.

③getId : renvoie l'identifiant correspondant à la classe AR actuelle

④getAuthKey : renvoie l'auth_key correspondant à la classe AR actuelle

⑤validateAuthKey : Cette méthode est plus importante et nous le ferons parlons-en plus tard Le cœur de la vérification de la connexion par cookie est atteint.

Implémentez l'interface dans notre User.php, puis réécrivez la méthode ci-dessus. Le code complet de User.php est le suivant :

$token]);
	}
 
	public static function findByUsername($username){     //①
		return static::findOne(['username'=>$username]); 
	}
 
	public function getId(){
		return $this->id;
	}
 
	public function getAuthkey(){
		return $this->auth_key;
	}
 
	public function validateAuthKey($authKey){
		return $this->auth_key === $authKey;
	}
 
	public function validatePassword($password){          //②
		return $this->password === md5($password);
	}
 
   	 /**
    	 * Generates "remember me" authentication key
    	 */
        public function generateAuthKey()                    //③
        {
       		$this->auth_key = \Yii::$app->security->generateRandomString();
       		$this->save();
        }
 
}
?>

①findByUsername() : Dans le code LoginForm, il s'agit de Méthode citée, le but est de renvoyer un élément de données identique au nom d'utilisateur dans la table de données, c'est-à-dire une instance AR, basée sur le nom d'utilisateur soumis par l'utilisateur.

②validatePassword() : Ici, le mot de passe soumis par l'utilisateur est comparé au mot de passe de la classe AR actuelle.

③generateAuthKey() : génère une clé d'authentification aléatoire pour la connexion aux cookies.

Au total, deux classes Model ont été écrites : LoginForm et User, l'une est utilisée pour recevoir les données soumises par les utilisateurs et l'autre est utilisée pour obtenir des données de la base de données.

Contrôleur

Le contrôleur, principalement utilisé pour la soumission de données, remplit les données soumises par l'utilisateur dans le modèle correspondant (Modèle), puis restitue davantage la vue (Vue ) en fonction des informations renvoyées par le modèle, ou exécuter une autre logique.

Ici, nommez le contrôleur LoginController.php. Voici le code d'implémentation complet :

<?php
 
namespace app\controllers;
 
use Yii;
use yii\filters\AccessControl;
use yii\web\Controller;
use yii\filters\VerbFilter;
use app\models\LoginForm;
use app\models\ContactForm;
 
class SiteController extends Controller
{
    public function actionIndex()
    {
        return $this->render(&#39;index&#39;);
    }
 
    public function actionLogin()
    {
        if (!\Yii::$app->user->isGuest) {     //①
            return $this->goHome();
        }
 
        $model = new LoginForm();             //②
        if ($model->load(Yii::$app->request->post()) && $model->login()) {      //③
            return $this->goBack();          //④
        }
        return $this->render(&#39;login&#39;, [      //⑤
            &#39;model&#39; => $model,
        ]);
    }
 
    public function actionLogout()
    {
        Yii::$app->user->logout();
 
        return $this->goHome();
    }
}

① Premier juge de Yii::$app->user->isGuest, si le le mode utilisateur actuel est le mode invité, c'est-à-dire non connecté. Si l'utilisateur est connecté, les informations de l'utilisateur actuellement connecté seront stockées dans la classe d'utilisateurs.

② Si ​​vous êtes actuellement un visiteur, un modèle LoginForm sera d'abord instancié

③ Cette ligne de code est au cœur de toute la méthode de connexion, d'abord : $model->load( Yii::$ app->request->post()) remplit les données de publication dans $model, c'est-à-dire le modèle LoginForm. Si true est renvoyé, le remplissage est réussi. Suivant : $model->login() : Exécutez la méthode login() dans la classe LoginForm. Vous pouvez voir à partir de la méthode login() qu'une série de vérifications sera effectuée.

Vue

Après avoir implémenté le modèle et le contrôleur, l'étape suivante est la partie vue Puisque l'utilisateur doit saisir des données, nous devons fournir un formulaire dans Yii2, ActiveForm est fourni pour. Générez rapidement le formulaire, le code est le suivant :

<?php
 
/* @var $this yii\web\View */
/* @var $form yii\bootstrap\ActiveForm */
/* @var $model app\models\LoginForm */
 
use yii\helpers\Html;
use yii\bootstrap\ActiveForm;
 
$this->title = &#39;Login&#39;;
$this->params[&#39;breadcrumbs&#39;][] = $this->title;
?>
<div class="site-login">
    <h1><?= Html::encode($this->title) ?></h1>
    <p>Please fill out the following fields to login:</p>
    <?php $form = ActiveForm::begin([
        &#39;id&#39; => &#39;login-form&#39;,
        &#39;options&#39; => [&#39;class&#39; => &#39;form-horizontal&#39;],
        &#39;fieldConfig&#39; => [
            &#39;template&#39; => "{label}\n<div class=\"col-lg-3\">{input}</div>\n<div class=\"col-lg-8\">{error}</div>",
            &#39;labelOptions&#39; => [&#39;class&#39; => &#39;col-lg-1 control-label&#39;],
        ],
    ]); ?>
        <?= $form->field($model, &#39;username&#39;)->textInput([&#39;autofocus&#39; => true]) ?>
        <?= $form->field($model, &#39;password&#39;)->passwordInput() ?>
        <?= $form->field($model, &#39;rememberMe&#39;)->checkbox([
            &#39;template&#39; => "<div class=\"col-lg-offset-1 col-lg-3\">{input} {label}</div>\n<div class=\"col-lg-8\">{error}</div>",
        ]) ?>
        <div class="form-group">
            <div class="col-lg-offset-1 col-lg-11">
                <?= Html::submitButton(&#39;Login&#39;, [&#39;class&#39; => &#39;btn btn-primary&#39;, &#39;name&#39; => &#39;login-button&#39;]) ?>
            </div>
        </div>
    <?php ActiveForm::end(); ?>
    <div class="col-lg-offset-1" style="color:#999;">
        You may login with <strong>admin/admin</strong> or <strong>demo/demo</strong>.<br>
        To modify the username/password, please check out the code <code>app\models\User::$users</code>.
    </div>
</div>

Apprentissage recommandé : yii framework

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Article précédent:yii Que lis-tu en anglais ?Article suivant:yii Que lis-tu en anglais ?