Я следовал руководству по аутентификации в CAKEPHP http://www.google.com/url?sa=D&q=http://book.cakephp.org/view/1250/Authentication
И я следовал руководству по настройке веб-сервиса REST: http://book.cakephp.org/view/1239/The-Simple-Setup
Это точно мой app_controller:
class AppController extends Controller {
var $components = array('DebugKit.Toolbar', 'Session', 'Auth');
var $helpers = array('Html','Javascript', 'Session', 'Ajax', 'Facebook.Facebook');
function beforeFilter()
{
// importa modello Season
$this->Season = ClassRegistry::init('Season');
// ricava la variabile di sessione
$id = $this->Session->read('editable_season_id');
// verifica se tale id è esistente
$exist = $this->Season->exist($id);
// se non esiste o è un valore non valido o è nullo
if((is_null($id)) || (!is_numeric($id) || (!$exist)))
{
// cerca l'id della stagione più recente
$id = $this->Season->getLastSeasonId();
// se esiste assegnalo ad una var di sessione
if($id)
{
$this->Session->write("editable_season_id", $id);
$title = $this->Season->getSeasonName($id);
$this->Session->write("editable_season_title", $title);
$this->redirect($this->referer());
} else { // altrimenti lancia errore
$seasons = $this->Season->getSeasons();
$this->cakeError('defaultSesonNotFound', array('seasons' => $seasons));
}
}
}
}
Теперь в каждом контроллере я перезаписываю функцию beforeFilter и разрешаю некоторые действия.Например, я хочу поделиться своим REST со всеми, поэтому в моем контроллере:
function beforeFilter() {
parent::beforeFilter();
$this->Auth->allow('showMatchesBySeasonId', 'matchDetails', 'view');
}
, где view - это имя моей службы REST.При первом вызове функции VIEW я буду перенаправлен на действие входа в систему.Если я снова вызову VIEW, он будет выполнен без проблем, и будет отображена информация, и проблем не будет, пока на моем компьютере не будет сохранен файл cookie с именем «CAKEPHP» (если я очищу кэш памяти, возникнет та же проблема).Зачем?Как я могу избежать этого поведения?
С уважением!