AuthComponentを使用してユーザーにログインできません。ユーザーテーブルの名前はusersであり、user_id、user_passwordなどのいくつかの重要なフィールドがあり、パスワードフィールドにハッシュはありません。
これは私のAppControllerです
class AppController extends Controller {
public $components = array(
'Session',
'Auth' => array(
'loginRedirect' => array('controller' => 'users', 'action' => 'index'),
'logoutRedirect' => array('controller' => 'users', 'action' => 'home'),
'authError' => 'You cannot view this page',
'authorize' => array('controller')
)
);
public function isAuthorize($user) {
return true;
}
public function beforeFilter() {
$this->Auth->allow('home');
}
}
これは私のUsersControllerです
class UsersController extends AppController {
public function login() {
if ($this->request->is('post')) {
if ($this->Auth->login()) {
$this->redirect($this->Auth->redirect());
} else {
$this->Session->setFlash('Cannot login in');
}
}
}
}
これは私のユーザーモデルです。
class User extends AppModel {
public $name = 'User';
public $primaryKey = 'user_id';
public $belongsTo = 'Group';
}
これは私の見解です
<h2>Login</h2>
<?php
echo $this->Form->create();
echo $this->Form->input('user_id', array('label' => 'User ID', 'type' => 'text'));
echo $this->Form->input('user_password', array('label' => 'Password', 'type' => 'password'));
echo $this->Form->end('Login');
?>
修正したuser_idとパスワードを入力してログインボタンを押すと、UsersControllerからログインできないというメッセージが表示されました。ここで何が悪かったのですか?
また、AuthComponent:login()の概念、データベースに対してuser_idとパスワードをチェックする方法、user_idを含むフィールド、パスワードを含むフィールドをどのように知るのか、私は本当に理解していません。
助けてください。ありがとう。Kongthap