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

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

新規登録して質問してみよう
ただいま回答率
85.35%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

コールバック

コールバックは他のコードに引数として渡されるコードのことを指します。

CakePHP

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

Q&A

解決済

3回答

2184閲覧

CakePHPのCMSチュートリアルでbeforeSaveコールバックが呼ばれない

taoyagi

総合スコア4

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

コールバック

コールバックは他のコードに引数として渡されるコードのことを指します。

CakePHP

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

0グッド

0クリップ

投稿2020/02/14 11:22

編集2020/02/14 12:06

前提・実現したいこと

CakePHPのCMSチュートリアルを学習しています。
データベースを更新する前にエンティティのデータを加工したいと思っています。
そのため、beforeSaveコールバックを発生させたい。

発生している問題

beforeSaveコールバックが呼ばれない。

該当のソースコード#1(ArticlesTable.php)

PHP

1 public function beforeSave($event, $entity, $options) 2 { 3 $this->log('aaaaaaaaaaaaaaaaaaaa'); 4 if ($entity->tag_string) 5 { 6 $entity->tags = $this->_buildTags($entity->tag_string); 7 } 8 }

呼び元のソースコード#2(ArticlesController.php)

PHP

1 public function edit($id = null) 2 { 3 $article = $this->Articles->get($id, [ 4 'contain' => ['Tags'], 5 ]); 6 if ($this->request->is(['patch', 'post', 'put'])) { 7 $article = $this->Articles->patchEntity($article, $this->request->getData()); 8 if ($this->Articles->save($article)) { 9 $this->Flash->success(__('The article has been saved.')); 10 11 return $this->redirect(['action' => 'index']); 12 } 13 $this->Flash->error(__('The article could not be saved. Please, try again.')); 14 } 15 $users = $this->Articles->Users->find('list', ['limit' => 200]); 16 $tags = $this->Articles->Tags->find('list', ['limit' => 200]); 17 $this->set(compact('article', 'users', 'tags')); 18 }

試したこと#1

ログを出力するように、beforeSaveメソッド内にログを埋め込みました。
(該当のソースコード#1)
しかし、ログファイルにログが出力されていませんでした。

試したこと#2

$this->Articles をdebug関数にてログに出力しました。

ArticlesController.php

PHP

1 $this->log(debug($this->Articles)); 2 if ($this->Articles->save($article)) {

ログ

2020-02-14 11:46:32 Error: App\Model\Table\ArticlesTable Object ( [registryAlias] => Articles [table] => articles [alias] => Articles [entityClass] => App\Model\Entity\Article [associations] => Array ( [0] => users [1] => tags [2] => articlestags ) [behaviors] => Array ( [0] => Timestamp ) [defaultConnection] => default [connectionName] => default )

補足情報

【バージョン情報】
PHPのバージョン 5.6.40
CakePHPのバージョン 3.8.9

【現在学習しているサイトとURL】
CMS チュートリアル - タグとユーザー
https://book.cakephp.org/3/ja/tutorials-and-examples/cms/tags-and-users.html#id9

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nojimage

2020/02/14 11:24

保存は成功している状態ですか?
taoyagi

2020/02/14 11:28

はい、保存は成功しています。
guest

回答3

0

$this->ArticlesArticlesTable のインスタンスではない可能性があります。
debug関数等で、$this->Articles のクラス名を確認してみてください。

ArticleTableでなかった場合は、ArticleTable.phpのファイル名、配置パス名を確認してみてください。

投稿2020/02/14 11:37

nojimage

総合スコア959

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

taoyagi

2020/02/14 12:11

早速のご回答ありがとうございます。 「$this->Articles のクラス名」を確認してみました。(詳細:試したこと#2)
guest

0

Bakeコマンドにてコードを再生成して解決

正直お手上げでしたので、以下のコマンドでarticles周りを再作成したら、beforeSaveメソッドが呼ばれるようになりました。

$ bin/cake bake all articles

投稿2020/02/14 23:40

taoyagi

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

自己解決

Bakeコマンドにて再生成して解決

正直お手上げでしたので、以下のコマンドでarticles周りを再作成したら、beforeSaveメソッドが呼ばれるようになりました。

$ bin/cake bake all articles

投稿2020/02/14 23:38

taoyagi

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問