2011-11-02 21 views
5

Bu öğretici kullandı: http://book.cakephp.org/2.0/en/tutorials-and-examples/blog-auth-example/auth.htmlÇağrı olmayan bir nesne üzerinde() izin yetkilendirme

/benim ilk formunu oluşturmak kullanıcının uygulamayı oluşturmak için, ancak bir hata iletisiyle başarısız olur:

Fatal error: Call to a member function allow() on a non-object in /home/public_html/cake/app/Controller/UsersController.php on line 18 

:

$this->Auth->allow('add', 'logout'); 

yukarıdaki satır fonksiyonunun bir üyedir:

Bu, 18 hattı ius

Benim bütün UsersController.php:

<?php 
class UsersController extends AppController { 

    public function login() { 
     if ($this->Auth->login()) { 
      $this->redirect($this->Auth->redirect()); 
     } else { 
      $this->Session->setFlash(__('Invalid username or password, try again')); 
     } 
    } 

    public function logout() { 
     $this->redirect($this->Auth->logout()); 
    } 

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

    public function index() { 
     $this->User->recursive = 0; 
     $this->set('users', $this->paginate()); 
    } 

    public function view($id = null) { 
     $this->User->id = $id; 
     if (!$this->User->exists()) { 
      throw new NotFoundException(__('Invalid user')); 
     } 
     $this->set('user', $this->User->read(null, $id)); 
    } 

    public function add() { 
     if ($this->request->is('post')) { 
      $this->User->create(); 
      if ($this->User->save($this->request->data)) { 
       $this->Session->setFlash(__('The user has been saved')); 
       $this->redirect(array('action' => 'index')); 
      } else { 
       $this->Session->setFlash(__('The user could not be saved. Please, try again.')); 
      } 
     } 
    } 

    public function edit($id = null) { 
     $this->User->id = $id; 
     if (!$this->User->exists()) { 
      throw new NotFoundException(__('Invalid user')); 
     } 
     if ($this->request->is('post') || $this->request->is('put')) { 
      if ($this->User->save($this->request->data)) { 
       $this->Session->setFlash(__('The user has been saved')); 
       $this->redirect(array('action' => 'index')); 
      } else { 
       $this->Session->setFlash(__('The user could not be saved. Please, try again.')); 
      } 
     } else { 
      $this->request->data = $this->User->read(null, $id); 
      unset($this->request->data['User']['password']); 
     } 
    } 

    public function delete($id = null) { 
     if (!$this->request->is('post')) { 
      throw new MethodNotAllowedException(); 
     } 
     $this->User->id = $id; 
     if (!$this->User->exists()) { 
      throw new NotFoundException(__('Invalid user')); 
     } 
     if ($this->User->delete()) { 
      $this->Session->setFlash(__('User deleted')); 
      $this->redirect(array('action'=>'index')); 
     } 
     $this->Session->setFlash(__('User was not deleted')); 
     $this->redirect(array('action' => 'index')); 
    } 
} 
?> 

o happends mu Neden?

cevap

13

Auth Compenent'in gerçekten AppController'ınızda çağrıldığından emin olun. Bir AppController aşağıdaki kodla Kontrolörler dizinde AppController.php oluşturmak yoksa:

Auth bileşeni AppController bir kamu değişkeninde denir, bu nedenle kontrolör şu şekilde görünecektir
<?php 
    class AppController extends Controller { 
    } 
?> 

:

<?php 
    class AppController extends Controller { 
    public $components = array('Auth'); 
    } 
?> 

Auth şu anda uygulamanızın tamamında kullanılabilir. Ayrıca UsersController'ınızda AuthComponent'u da arayabilirsin, ancak bu sadece bu özel denetleyici için kullanılabilir hale getirebilirdi. Muhtemelen tüm başvurunuzda kimlik doğrulamayı kullanmak istersiniz.

+3

Sadece söylediklerinize bir eklenti. CakePHP 2.0'da, AppController Kontrolörler klasöründe ve 1.3'de olduğu gibi uygulama klasöründe DEĞİLDİR. Bu, bileşeni çağırdığımdan, ama gerçek AppController'ın kendisinden bile mahrum bıraktı! –

İlgili konular