[英]cakePHP authentication problems
我无法确定CakePHP中Auth组件的工作方式。 我正在使用2.1
我的登录完美无缺,据我所知,我可以在appController中设置默认组件,如下所示。
// App controller:
public $components = array(
'Session',
'Auth' => array(
'loginAction' => array(
'controller' => 'users',
'action' => 'login',
),
'authError' => "Your username and password is incorrect, please try again.",
'authenticate' => array(
'Form' => array(
'scope' => array('User.user_status_id' => 1)
)
),
'redirect' => array("controller" => "users", "action" => "profile"),
'loginRedirect' => array("controller" => "users", "action" => "profile")
)
);
public function beforeFilter() {
$this->Auth->allow("home");
if($this->Auth->loggedIn() == true) {
$this->set("user_name",$this->Auth->user("first_name")." ".$this->Auth->user("last_name"));
$this->set("loggedIn",true);
if($this->Auth->user("user_type_id") == 5) {
$this->set("navigation","navigation_admin");
} else {
$this->set("navigation","navigation_loggedin");
}
} else {
$this->set("loggedIn",false);
$this->set("navigation","navigation_notloggedin");
}
}
home位于/app/view/home.ctp,但是,如果没有登录我就无法访问该页面。接下来,我有2个不同的用户级别,普通用户和管理员。 如果您不是管理员,我想限制控制器中的某些操作。
在我的UserController中,我有一个例子:
public function beforeFilter() {
parent::beforeFilter();
$this->Auth->allow("login");
if($this->Auth->user("user_type_id") != 5) {
$this->Auth->allow("login","profile");
}
}
但是,无论用户类型如何,每个人都可以查看操作。
在页面控制器中,我还具有以下内容:
public function beforeFilter() {
parent::beforeFilter();
$this->Auth->allow("*");
}
但是我必须登录才能查看任何页面。
我坚信自己做错了什么,但是我无法解决问题,有什么帮助吗?
首先, home
不是控制器上的动作,因此$this->Auth->allow("home");
不会有效果。 $this->Auth->allow("display");
但可以允许看到所有页面(不确定是否要这样做)。
其次,您正在使用$this->Auth->allow("*");
在调用父级的beforeFilter之后,这意味着AppController::beforeFilter()
会将其视为未登录用户,因为它不知道事后允许您做什么。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.