[英]Yii2 step-by-step guide on login from table in MySQL
我开始在Yii2中迈出第一步。 到目前为止,我能够编写一个应用程序并将数据库中的表连接到它,就像我在Yii1中学到的那样。
该表是contacts
,我的创建视图中的表单将数据发送到数据库没有任何问题。
问题是我只能使用内置在Yii2中的静态用户模型中的Admin / Admin或demo / demo登录。
在Yii1.xx中,我设法使用COMPONENTS / useridentity从数据库中的表中验证登录,就像这样(我使用了一个名为utilizador
的表,其中包含字段id
, utilizador
和password
):
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指南,但不知道如何从我的控制器中的供应商文件夹中调用路由。 做了几次尝试,但都失败了。
有人可以教我如何在Yii2中验证从数据库登录,优先不使用扩展吗?
编辑
我在Stack Overflow Yii Framework 2.0使用用户数据库登录时 阅读了本教程
并且还研究了来自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 Model:
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;
}
}
有任何想法吗 ?? - >谢谢......
我不知道我还应该做什么,也许它在验证密码或找到用户名方面存在问题,在Yii2调试中它显示正确连接到mysql数据库。
不要触及siteController actionLogin(),因为它等于高级模板,我认为最好保持这种方式。
编辑3 - > 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. 在那里,我可以轻松地查询数据库,并使一个良好的登录系统工作。
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)首先根据自己的要求创建数据库表。
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;
现在转到Model生成器并使用q_user表创建Model
它将生成一个QUser模型。 在这个模型中你将不得不
实现IdentityInterface
class 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模型,以便它返回用户
class 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*[az])(?=\\S*[AZ])(?=\\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; }
}
就是这样可以解决你的问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.