質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.34%

  • CakePHP

    2388questions

    CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

CakePHP3.6 エラーメッセージがわからない

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 228

nnahito

score 1759

 環境など

  • CakePHP3.6
  • Docker or AWS
  • php7.2

 質問したい事象

何かしらエラーが発生した際に、だいたい以下のエラーメッセージが表示されます。

Error: [Error] Call to a member function user() on boolean

しかし、エラー該当箇所は別の場所にあります。
(つまり、エラーメッセージが役に立たない)

 質問詳細

CakePHP3.6(PHP7.2)を利用しています。
CakePHPで何かしらエラーが発生した際、以下のエラーメッセージがよく表示されます。

Error: [Error] Call to a member function user() on boolean
Stack Trace:
#0 /var/www/html/src/Controller/ErrorController.php(55): App\Controller\AppController->beforeRender(Object(Cake\Event\Event))
#1 /var/www/html/vendor/cakephp/cakephp/src/Event/EventManager.php(353): App\Controller\ErrorController->beforeRender(Object(Cake\Event\Event))
#2 /var/www/html/vendor/cakephp/cakephp/src/Event/EventManager.php(330): Cake\Event\EventManager->_callListener(Array, Object(Cake\Event\Event))
#3 /var/www/html/vendor/cakephp/cakephp/src/Event/EventDispatcherTrait.php(114): Cake\Event\EventManager->dispatch(Object(Cake\Event\Event))
#4 /var/www/html/vendor/cakephp/cakephp/src/Controller/Controller.php(777): Cake\Controller\Controller->dispatchEvent('Controller.befo...')
#5 /var/www/html/vendor/cakephp/cakephp/src/Error/ExceptionRenderer.php(329): Cake\Controller\Controller->render('error500')
#6 /var/www/html/vendor/cakephp/cakephp/src/Error/ExceptionRenderer.php(205): Cake\Error\ExceptionRenderer->_outputMessage('error500')
#7 /var/www/html/vendor/cakephp/cakephp/src/Error/Middleware/ErrorHandlerMiddleware.php(118): Cake\Error\ExceptionRenderer->render()
#8 /var/www/html/vendor/cakephp/cakephp/src/Error/Middleware/ErrorHandlerMiddleware.php(100): Cake\Error\Middleware\ErrorHandlerMiddleware->handleException(Object(Error), Object(Cake\Http\ServerRequest), Object(Cake\Http\Response))
#9 /var/www/html/vendor/cakephp/cakephp/src/Http/Runner.php(65): Cake\Error\Middleware\ErrorHandlerMiddleware->__invoke(Object(Cake\Http\ServerRequest), Object(Cake\Http\Response), Object(Cake\Http\Runner))
#10 /var/www/html/vendor/cakephp/cakephp/src/Http/Runner.php(51): Cake\Http\Runner->__invoke(Object(Cake\Http\ServerRequest), Object(Cake\Http\Response))
#11 /var/www/html/vendor/cakephp/cakephp/src/Http/Server.php(98): Cake\Http\Runner->run(Object(Cake\Http\MiddlewareQueue), Object(Cake\Http\ServerRequest), Object(Cake\Http\Response))
#12 /var/www/html/webroot/index.php(40): Cake\Http\Server->run()
#13 {main}

しかしながら、エラーの内容はもっと別のところにあります。
例えばyum installを実行するのを忘れていた等。。。

CakePHPは、AppControllerにAuth処理を入れたらエラーメッセージが固定されてしまうのでしょうか?
それとも私のやり方が間違っているのでしょうか。

後者の場合、修正方法をご教示いただきたいです……

また、beforeFilterbeforeRenderを公開可能な部分で以下に提示させていただきます。

   public function beforeFilter(Event $event)
    {
        // コントローラー名を取得
        $controllerName = $this->getRequest()->getParam('controller');

        // そのコントローラー内でアクセス許可するアクションリストを取得
        $allowAccessMethod = $this->_getAllowAccessMethod($controllerName);
        if ($allowAccessMethod) {
            // アクセス許可アクションリストを、登録
            $this->Auth->allow($allowAccessMethod);
        }

        return parent::beforeFilter($event);
    }

_getAllowAccessMethodメソッドは別途定義してあり、配列が返ります。

    public function beforeRender(Event $event)
    {
        // ユーザのログイン情報を取得
        $user = $this->Auth->user();

        // ビューに渡す
        $this->set('user', $user);
    }

申し訳ありませんが、よろしくお願いいたします。

 追記

Authの認証について追記させていただきます。
今回、ユーザのログインなどには、CakePHPのAuthコンポーネントのIdentifyは使っていません。
理由として、認証を外部のSaaSに委託しているため、APIを叩いてユーザの有無、ユーザ情報の正誤をSaaS側で判断し、
SuccessかFailを返してもらっているからです。
こちらではユーザの情報をほぼ持っていないので、
ログインが成功した際は、$this->Auth->setUser($user);というふうに、手動でデータをセッションに追加しています。

こちらも関係あるのでしょうか?

 追記2

本文の「beforeRender」の処理の中の、

// ユーザのログイン情報を取得
$user = $this->Auth->user();

部分でAuthを使わない($user = '';)状態にすると、正常にエラーメッセージが表示されるようになりました

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • nnahito

    2018/10/10 12:29

    「Cake\Controller\Component\AuthComponent 」でした!

    キャンセル

  • asahina1979

    2018/10/10 12:30

    追記2の直前で?

    キャンセル

  • nnahito

    2018/10/10 13:20

    はい、そうですね!   echo get_class($this->Auth); (改行) // ユーザのログイン情報を取得 (改行) $user = $this->Auth->user();  です!

    キャンセル

回答 2

checkベストアンサー

+1

エラーメッセージを見るとエラー出力時のエラーのように見えます。

#0 /var/www/html/src/Controller/ErrorController.php(55): App\Controller\AppController->beforeRender(Object(Cake\Event\Event))

以下の2のエラーで表示が上書きされているように見えます。

  1. なんらかのエラー
  2. ErrorController によってエラー処理(ここで再度エラー)

ErrorControllerの処理やエラー時にAuthの設定がどうなるかを見てみると良いと思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/10/11 11:01

    ご回答有り難うございます!

    > エラー時にAuthの設定がどうなるかを見てみる

    こちらなのですが、Authの設定……というのは、「$user = $this->Auth->user();」の部分という意味でしょうか?

    キャンセル

  • 2018/10/11 11:03

    例えばエラー時に、

    var_dump($this->Auth->user());
    die;

    のようにしても、Authのエラーが出ますね……
    これは、Auth自体が使えていないことになると思うのですが、
    原因の調べ方がわからず…

    キャンセル

  • 2018/10/11 13:35

    `ErrorController` で `$this->Auth` が未定義だということはどこかで `loadComponent` が実行されていないことを疑うことができます。

    なので `ErrorController` で `loadComponent` をしているメソッドをオーバーライドしていたりしませんか?

    たとえば初期だと`parent`していないので上書きされてしまいます。
    https://github.com/cakephp/app/blob/master/src/Controller/ErrorController.php

    キャンセル

  • 2018/10/11 17:08 編集

    ご返信有難うございます。

    > たとえば初期だと`parent`していないので上書きされてしまいます。

    今、すべてのControllerとComponentを確認したのですが、
    すべてinitializeメソッドの中に、「parent::initialize();」が書かれておりました……

    キャンセル

  • 2018/10/11 21:41 編集

    ログを見る限りではErrorControllerからのエラーだと思われるのでそこを調査ですね...

    ErrorControllerのinitializeメソッドでparent::initialize()のすぐ下で dd($this->Auth) をしてみてセットされてるか確認してみて下さい。

    セットされてなければ試しにErrorControllerでloadComponentしてみてください

    キャンセル

  • 2018/10/12 13:59

    ご返信有難うございます。
    今確認したのですが、ErrorControllerのinitializeに「parent::initialize()」が ない のですが……
    もしかしてこれ原因だったりします?

    キャンセル

  • 2018/10/12 15:23

    そうですね。

    ErrorController::beforeRender() までにAuthコンポネーントをloadComponentしてないからエラーになっていると思いますので。

    キャンセル

  • 2018/10/12 15:25

    スタックトレースの読み方がわからないほうだったのか(ぉ

    キャンセル

  • 2018/10/12 19:28

    あー……なんてことだ……ありがとうございます!
    きれいにエラーが表示されました!
    なんでここの「parent::initialize()」が消えていたのだろう……

    キャンセル

  • 2018/10/12 20:56

    良かったです!

    cakeのプロジェクト作った初期状態だとErrorControllerにはparent::initialize()がない状態だからですかねー

    何もしてなければ無いままです

    キャンセル

  • 2018/10/12 21:00

    エラーハンドリング用のコントローラーはDB処理(loadModel)を省く必要があるため 親クラスをロードシてはいけませんよ

    キャンセル

+1

エラーメッセージが固定されるわけではなく、Auth 処理に問題があるからエラーが出ているのです。
※Auth 処理はどの画面でも、画面の処理に先立ち呼び出されますから、そこでエラーが出れば「常に同じ場所でエラーが起きている」ことになります

この例でいうと、おそらく $this->Auth が正しくないので、$this->Auth->user() が呼び出せなくなっています。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/10/10 11:22

    ご回答有り難うございます。

    > $this->Auth が正しくないので、$this->Auth->user() が呼び出せなくなっています。

    なるほど……
    通常呼び出せますが、なにかのきっかけで呼び出せなくなっている…という認識で大丈夫でしょうか?
    となると「beforeRender」の処理がなにかおかしい感じでしょうか?

    キャンセル

  • 2018/10/10 11:26

    beforeRecder ではなく、$this->Auth を設定しているところで何かしくじっていると思います。

    キャンセル

  • 2018/10/10 11:31

    ご返信有難うございます。
    思い当たる点が一つあり、本文に追記させていただきました。

    認証処理をSaaSに委託しておりこちら側ではユーザ情報を持っておらず、AuthのIdentifyメソッドを使っていません。(setUserを使っている)
    もしかしてこの場合、なにか必要な処理があったりするのでしょうか?

    キャンセル

同じタグがついた質問を見る

  • CakePHP

    2388questions

    CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。