2011-11-02 12 views
5

私はこのチュートリアルで使用:ユーザーのアプリを作成/私の最初のフォームを構築するにhttp://book.cakephp.org/2.0/en/tutorials-and-examples/blog-auth-example/auth.htmlコール(許可) - 承認

を、それはエラーメッセージで失敗します。

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

これは、18行IUS:

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

上の行が関数のメンバーである:

マイ全体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')); 
    } 
} 
?> 

それはhappendsないのはなぜ?

答えて

13

Auth compenentが実際にAppControllerで呼び出されていることを確認してください。次のコードを使用してコントローラのディレクトリにAppController.phpをのAppControllerを作成していない場合:

<?php 
    class AppController extends Controller { 
    } 
?> 

AuthコンポーネントはAppControllerの中にパブリック変数で呼び出されるので、コントローラは次のようになります。

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

あなたのアプリケーション全体で認証が利用できるようになりました。 UsersControllerのAuthComponentも呼び出すことができますが、それは特定のコントローラだけが利用できるようにします。おそらく、アプリケーション全体で認証を使用したいと思うでしょう。

+3

あなたが言っていることにちょうどアドオン。 CakePHP 2.0では、AppControllerはControllersフォルダにあり、1.3のようにappフォルダにはありません。これは、私がコンポーネントを呼び出すときに私のことを気にしましたが、実際のAppController自体ではありませんでした。 –

関連する問題