Страница входа CakePHP никуда не денется - PullRequest
0 голосов
/ 13 февраля 2012

Я пытался настроить страницу входа в систему, но когда я пытаюсь войти в систему, даже с неверным именем пользователя и паролем, торт перенаправляет на страницу входа (функция выхода из системы перенаправляет правильно).Даже если я подключу неверную информацию, я не получаю никаких сообщений об ошибках, я не получаю ее.Вот мой код контроллера:

class UsersController extends AppController {
public $name='Users';
public $layout='pagelayout';
public $uses=array('User');



public function beforeFilter() {
    parent::beforeFilter();
    $this->Auth->allow('add', 'logout', 'overview');
}

public function login() {
$this->set('title', 'Log in to your Gulf Shores 4 Less account');
if ($this->request->is('post')) {
    if ($this->Auth->login()) {
        return $this->redirect($this->Auth->redirect());
    } else {
        $this->Session->setFlash(__('Username or password is incorrect'), 'default', array(), 'auth');
    }
}

}

и вот моя модель:

<?php
App::uses('AuthComponent', 'Controller/Component');
class User extends AppModel {
public $name='User';
public $hasMany=array('Unit', 'Complex', 'Coupon', 'Location', 'Image', 'Charter', 'Course', 'Nightclub', 'Store');

public function beforeSave() {
if (isset($this->data[$this->alias]['password'])) {
    $this->data[$this->alias]['password'] = AuthComponent::password($this->data[$this->alias]['password']);
}
return true;
}
public $validate = array(
    'username' => array(
        'required' => array(
            'rule' => array('notEmpty'),
            'message' => 'A username is required'
        )
    ),
    'password' => array(
        'required' => array(
            'rule' => array('notEmpty'),
            'message' => 'A password is required'
        )
    ),
    'role' => array(
        'valid' => array(
            'rule' => array('inList', array('admin', 'advertiser')),
            'message' => 'Please enter a valid role',
            'allowEmpty' => false
        )
    )
  );
}

?>

Вот код из AppController:

<?php
class AppController extends Controller {
 public $components = array(
    'Session',
    'Auth' => array(
        'loginRedirect' => array('controller' => 'users', 'action' => 'overview'),
        'logoutRedirect' => array('controller' => 'pages', 'action' => 'index')
    )
);


function beforeFilter() {
    $this->Auth->allow('login','index', 'view', 'condos', 'houses', 'hotels_and_motels', 'print_all_coupons', 'print_coupon', 'search', 'golf', 'charters', 'events', 'nightlife', 'shopping', 'visitors_info', 'contact_us');
}
}
?>

и вот код вида:

<div class="users form">
<?php echo $this->Session->flash('auth'); ?>
<?php echo $this->Form->create('User');?>
<fieldset>
    <legend><?php echo __('Please enter your username and password'); ?></legend>
<?php
    echo $this->Form->input('username');
    echo $this->Form->input('password');
?>
</fieldset>
<?php echo $this->Form->end(__('Login'));?>
</div>

Как вы можете видеть, я в значительной степени скопировал и вставил то, что было в руководстве Cakephp-2.0 для этого.Единственная разница между моей таблицей БД и руководством состоит в том, что мой пароль хранится в виде хеша MD5 в моей таблице пользователей.я не могу понять, где это сошло с рельсов.

Ответы [ 2 ]

1 голос
/ 13 февраля 2012

Убедитесь, что ваши пароли хранятся с использованием хеша компонента Auth.AFAIK, нет поддержки «простых» паролей md5.Хеши, которые генерирует Cake, сложнее, чем md5.

См. Документацию для получения информации о том, как хэшировать ваши пароли.Если вы переходите из приложения, которое использует хеширование md5, вам придется сбросить все пароли на случайные для всех ваших пользователей значения.

0 голосов
/ 14 февраля 2012

Вы можете попробовать использовать следующие коды в файле AppController.php

AppController.php

$this->Auth->authenticate = array(
            AuthComponent::ALL => array('userModel' => 'User'),
            'Form' => array(
                'fields' => array('username' => 'email')
            )
        );
        $this->Auth->authorize =false;
        $this->Auth->loginAction = array('controller' => 'users', 'action' => 'login');
        $this->Auth->fields = array('username' => 'email', 'password' => 'password');
        $this->Auth->loginRedirect = array('controller' => 'media', 'action' => 'index/');
        $this->Auth->logoutRedirect = '/logout';
        $this->Auth->loginError = 'Invalid e-mail / password combination. Please try again';
...