Cake php почему $ user ложно пытается войти - PullRequest
0 голосов
/ 08 января 2020

Я пытаюсь создать логин и зарегистрировать страницу с тортом php 3.8. Я успешно создал страницу регистрации, и все данные вводятся в базу данных, но как только я попробовал войти в систему, он не работает каждый раз. У меня нет ошибок, которые я вижу. Каждый раз, когда я вводю адрес электронной почты и пароль, он говорит: «Неверный адрес электронной почты или пароль, попробуйте еще раз».

Код ниже:

UserController. php

<?php
namespace App\Controller;

use Cake\Controller\Controller;
use Cake\Event\Event;

class UsersController extends AppController
{
 public function beforeFilter(Event $event)
{
    parent::beforeFilter($event);
    $this->Auth->allow('add');
    $this->Auth->allow(['add', 'logout']);
}

public function register()
{
    $user = $this->Users->newEntity();
    if ($this->request->is('post')) {
        // Prior to 3.4.0 $this->request->data() was used.
        $user = $this->Users->patchEntity($user, $this->request->getData());
        if ($this->Users->save($user)) {
            $this->Flash->success(__('The user has been saved.'));
            return $this->redirect(['action' => 'register']);
        }
        $this->Flash->_error_(__('Unable to add the user.'));
    }
    $this->set('user', $user);
}



public function login()
{
    if ($this->request->is('post')) {
        $user = $this->Auth->identify();
        if ($user) {
            $this->Auth->setUser($user);
            return $this->redirect($this->Auth->redirectUrl());
        }
        $this->Flash->_error_(__('Invalid email or password, try again'));
    }
}

public function logout()
{
    return $this->redirect($this->Auth->logout());
}
} 

AppController. php

public function initialize()
{
    parent::initialize();

    $this->loadComponent('RequestHandler', [
        'enableBeforeRedirect' => false,
    ]);
    $this->loadComponent('Flash');
    $this->loadComponent('Auth', [
        'loginRedirect' => [
            'controller' => 'Users',
            'action' => 'register'
        ],
        'logoutRedirect' => [
            'controller' => 'Pages',
            'action' => 'display',
            'home'
        ]
    ]);
}

    public function beforeFilter(Event $event)
{
    $this->Auth->allow(['index', 'view', 'display','register']);
} 

Пользователь. php

 protected function _setPassword($password)
   {
      if (strlen($password) > 0) {
        return (new DefaultPasswordHasher)->hash($password);
    }
}

AppCotroller. php

 public function initialize()
{
    parent::initialize();

    $this->loadComponent('RequestHandler', [
        'enableBeforeRedirect' => false,
    ]);
    $this->loadComponent('Flash');
    $this->loadComponent('Auth', [
        'loginRedirect' => [
            'controller' => 'Users',
            'action' => 'register'
        ],
        'logoutRedirect' => [
            'controller' => 'Pages',
            'action' => 'display',
            'home'
        ],
        'authenticate'=>[
            'Form'=>[
                'fields'=>['email'=>'email','password'=>'password']
            ]
        ]
    ]);
}

    public function beforeFilter(Event $event)
{
    $this->Auth->allow(['index', 'view', 'display','register','add']);
    $this->set('email',$this->Auth->user('email'));
}

login.ctp

<div class="users form">
<?= $this->Flash->render() ?>
<?= $this->Form->create() ?>
<fieldset>
   <legend><?= __('Please enter your email and password') ?></legend>
   <?= $this->Form->control('email') ?>
   <?= $this->Form->control('password') ?>
</fieldset>
<?= $this->Form->button(__('Login')); ?>
<?= $this->Form->end() ?>

Ответы [ 2 ]

0 голосов
/ 09 января 2020

Попробуйте это в вашей функции инициализации AppController ()

        'authorize' => ['Controller'], //tell application to check each and every controller request for valid authorization
        'authenticate' => [
            'Form' => [
                'userModel' => 'Users',
                'fields' => [
                    'username' => 'username',
                    'password' => 'password',
                    'status' => 1
                ]
            ]
        ],
        'unauthorizedRedirect' => $this->referer()

И, пожалуйста, разрешите также функцию входа в систему (в вашем пользовательском контроллере)

$this->Auth->allow(['add', 'logout', 'login']);
0 голосов
/ 08 января 2020

Ваша конфигурация поля должна указать ему, какое поле использовать в качестве имени пользователя:

'fields'=>['username'=>'email','password'=>'password']
...