关于从MySQL中的表登录的Yii2循序渐进指南

时间:2014-12-04 21:05:54

标签: php mysql login yii2

我开始在Yii2中迈出第一步。到目前为止,我能够编写一个应用程序并将数据库中的表连接到它,就像我在Yii1中学到的那样。

表格为contacts,我的创建视图中的表单将数据发送到数据库,没有任何问题。

问题是我只能使用内置于Yii2的静态用户模型中的Admin / Admin或demo / demo登录。

在Yii1.xx中,我设法使用COMPONENTS / useridentity从数据库中的表中验证登录,就像这样(我使用了一个名为utilizador的表,其中包含字段idutilizadorpassword):

class UserIdentity extends CUserIdentity
{

    public function authenticate() {
       $conexao=Yii::app()->db;
       $consulta="select utilizador,password from utilizador ";
       $consulta.="where utilizador='".$this->username."' and ";
       $consulta.="password='".$this->password."'";

       $resultado=$conexao->createCommand($consulta)->query();

       $resultado->bindColumn(1,$this->username);
       $resultado->bindColumn(2,$this->password);

       while($resultado->read()!==false){
        $this->errorCode=self::ERROR_NONE;
        return !$this->errorCode;
       }
   }

}

使用Yii2我已经阅读了很多教程,包括Stack Overflow中的一个,但是没有一个教程能让我了解从MySQL数据库登录用户名和密码的过程。 Yii2没有components / useridentity.php,我不知道从哪里开始,什么是正确的代码,使它能够覆盖开箱即用的静态用户模型。

我也尝试过扩展Yii2用户,阅读PDF指南,但不知道如何从我的控制器中的vendor文件夹中调用路径。做了几次但都失败了。

有人可以教我如何验证Yii2中的数据库登录,优先不使用扩展名吗?

修改

我在Stack Overflow中阅读了本教程 Yii Framework 2.0 Login With User Database

还研究了来自Yii2用户扩展的PDF ,但不知道如何处理以下部分和下一部分pdf。它讲的是路线,但我不知道如何使用它们:

2.3.1显示用户 Route / user / admin / index显示已注册用户的列表。您将能够看到许多有用的信息,例如注册时间和IP地址,确认和阻止状态等。

我也读过这个: http://www.yiiframework.com/doc-2.0/yii-web-user.html 但我认为它没有解决问题的步骤。

编辑2

我尝试在Yii基本模板中实现User Model和LoginForm Model来验证用户登录。创建了一个数据库并与之相关联。数据库作为表用户和字段用户名,密码,authKey,acessToken填充值。从ActiveRecord扩展用户模型并实现\ yii \ web \ IdentityInterface,以使内置的Yii2功能完成其工作。还写了方法 public static function tableName(){return'user'; }

每次我尝试登录时都会抛出 - >用户名或密码不正确,来自LoginForm模型中的validatepassword()。

这是我的代码: LoginForm模型:

namespace app\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()
{
    return [
        // username and password are both required
        [['username', 'password'], 'required'],
        // rememberMe must be a boolean value
        ['rememberMe', 'boolean'],
        // password is validated by validatePassword()
        ['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 boolean 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
 */
public function getUser()
{
    if ($this->_user === false) {
        $this->_user = User::findByUsername($this->username);
    }

    return $this->_user;
}

}

...这是我的User.php模型

<?php

namespace app\models;

use yii\db\ActiveRecord;

class User extends ActiveRecord implements \yii\web\IdentityInterface
{
public $id;
public $username;
public $password;
public $authKey;
public $accessToken;

public static function tableName() { return 'user'; }

   /**
 * @inheritdoc
 */
public static function findIdentity($id) {
    $user = self::find()
            ->where([
                "id" => $id
            ])
            ->one();
    if (!count($user)) {
        return null;
    }
    return new static($user);
}

/**
 * @inheritdoc
 */
public static function findIdentityByAccessToken($token, $userType = null) {

    $user = self::find()
            ->where(["accessToken" => $token])
            ->one();
    if (!count($user)) {
        return null;
    }
    return new static($user);
}

/**
 * Finds user by username
 *
 * @param  string      $username
 * @return static|null
 */
public static function findByUsername($username) {
    $user = self::find()
            ->where([
                "username" => $username
            ])
            ->one();
    if (!count($user)) {
        return null;
    }
    return new static($user);
}

/**
 * @inheritdoc
 */
public function getId() {
    return $this->id;
}

/**
 * @inheritdoc
 */
public function getAuthKey() {
    return $this->authKey;
}

/**
 * @inheritdoc
 */
public function validateAuthKey($authKey) {
    return $this->authKey === $authKey;
}

/**
 * Validates password
 *
 * @param  string  $password password to validate
 * @return boolean if password provided is valid for current user
 */
public function validatePassword($password) {
    return $this->password === $password;
}

}

任何想法? - &GT;感谢...

我不知道我该怎么做,也许它在验证密码或找到用户名方面存在问题,在Yii2调试中它显示正确连接到mysql数据库。 < / p>

不要触及siteController actionLogin(),因为它等于高级模板,我认为最好保持这种状态。

编辑3 - &gt; 4小时搞乱模型代码,在我阅读的每个解决方案中加入实践,它仍然会抛出“用户名或密码不正确”。从

public function validatePassword($attribute, $params)
{
    if (!$this->hasErrors()) {
        $user = $this->getUser();

        if (!$user || !$user->validatePassword($this->password)) {
            $this->addError($attribute, 'Incorrect username or password.');
        }
    }
}

我不想放弃,但我正在考虑回到旧的Yii1.xx.在那里,我可以轻松地查询数据库并使一个良好的登录系统正常工作。

2 个答案:

答案 0 :(得分:6)

Yii2高级应用程序默认带有来自数据库的登录部分的工作示例(我看到基本部分使用静态用户名和密码)。您无需安装任何额外的东西,只需查看代码即可。安装高级应用程序并查看前端。

简而言之,SiteController使用LoginModel进行验证,然后使用LoginModel的login()将User模型登录到User组件。

如果您不想使用用户模型,只需创建自己的模型并使用该模型。您不想使用默认的用户组件,只需创建自己的组件。这很容易做到。

修改 交配,删除变量的公开声明。

class User extends ActiveRecord implements \yii\web\IdentityInterface
{
public $id;
public $username;
public $password;
public $authKey;
public $accessToken;

你告诉Yii忽略数据库中的内容。

答案 1 :(得分:1)

创建自己的模型,然后使用它。我将在下面发布代码。

1)首先根据自己的要求创建一个数据库表。

 CREATE TABLE `q_user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `email` varchar(255) NOT NULL,
  `auth_key` varchar(32) NOT NULL,
  `password_hash` varchar(20) NOT NULL,
  `access_token` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; 
  • 现在转到模型生成器并使用q_user创建模型 表

  • 它将生成一个QUser模型。在这个模型中你必须要 实现IdentityInterface

    类QUser extends \ yii \ db \ ActiveRecord实现\ yii \ web \ IdentityInterface

现在实现所有方法。如果使用Netbeans命中alt + enter。

public function getAuthKey() {
        return $this->auth_key;
    }

    public function getId() {
        return $this->id;
    }

    public function validateAuthKey($authKey) {
       return $this->auth_key = $authkey;
    }

    public static function findIdentity($id) {

        return self::findOne($id);

    }

    public static function findIdentityByAccessToken($token, $type = null) {

        return $this->access_token;
    }

    public static function findByUsername($email){
        return self::findOne(['email'=>$email]);
    }

    public function validatePassword($password){
        return $this->password_hash === $password;
    }
  • 现在,在Login窗体中,您必须定义Quser模型 返回用户

    类LoginForm扩展了Model {     public $ username;     public $ password;     public $ email;     public $ rememberMe = true;

    private $_user = false;
    
    
    /**
     * @return array the validation rules.
     */
    public function rules()
    {
        return [
            // username and password are both required
            [['email', 'password'], 'required'],
            // rememberMe must be a boolean value
    
            ['rememberMe', 'boolean'],
            // password is validated by validatePassword()
            ['password', 'validatePassword'],
            ['password','match','pattern'=>'$\S*(?=\S*[a-z])(?=\S*[A-Z])(?=\S*[\d])\S*$','message'=>'Password must have atleast 1 uppercase and 1 number '],
            [['password'],'string','min'=>6],
            //email validation
            ['email','email']
        ];
    }
    
    /**
     * 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 boolean 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);
        }
        return false;
    }
    
    /**
     * Finds user by [[username]]
     *
     * @return User|null
     */
    public function getUser()
    {
        if ($this->_user === false) {
            $this->_user = QUser::findByUsername($this->email);
        }
    
        return $this->_user;
    }
    

    }

这就是解决你的问题。