我認爲它不是一個好主意,但方法很簡單。
使用的版本:CakePHP的v3.4.5
模板\用戶\ login.ctp:
<form method="post" action="<?= $this->Url->build(['controller'=>'Users', 'action' => 'login']) ?>">
<input type="text" name="id" value="">
<button type="submit">login</button>
</form>
控制器\ UsersController.php:
public function login()
{
if ($this->request->is('post')) {
$user = $this->Users->findById($this->request->getData()['id'])->first();
if ($user) {
$this->Auth->setUser($user);
return $this->redirect(['controller' => 'MyController', 'action' => 'MyAction']);
}
$this->Flash->error('Id not found.');
return $this->redirect($this->referer());
}
}
不要忘記在AppController中加載AuthComponent並允許非授權用戶使用登錄方法 - 描述內容爲here。
完美!非常感謝你。 :) – Tom