古いCakePHPで、簡易的にPHP5.3対応

1.2.6より古いCakePHPでは、PHP5.3以上にしたときに大量のE_DEPRECATEDエラーが出ます。

php.iniでerror_reportingを設定しても、debugモードが2の時は上書きされてしまうため、とても邪魔です。
セッションが切れたりするので、とりあえず無視したいですね。

CakePHPをアップデートするなどまともな解決法もありますが、一番簡単なのは、CakePHPのerror_reporing設定している部分を上書きしてしまうことです。

project/cake/libs/configure.php : 293

if (isset($config['debug'])) {
	if ($_this->debug) {
		//この行を編集
		//error_reporting(E_ALL);
		error_reporting(E_ALL & ~E_DEPRECATED);

		if (function_exists('ini_set')) {
			ini_set('display_errors', 1);
		}

		if (!class_exists('Debugger')) {
			require LIBS . 'debugger.php';
		}
		if (!class_exists('CakeLog')) {
			require LIBS . 'cake_log.php';
		}
		Configure::write('log', LOG_NOTICE);
	} else {
		error_reporting(0);
		Configure::write('log', LOG_NOTICE);
	}
}

強引ですが簡単ですね。

デザインも頼めるシステム開発会社をお探しならBPS株式会社までどうぞ 開発エンジニア積極採用中です! Ruby on Rails の開発なら実績豊富なBPS

この記事の著者

baba

ゆとりプログラマー。 高校時代から趣味でプログラミングを初め、そのままコードを書き続けて現在に至る。慶應義塾大学環境情報学部(SFC)卒業。BPS設立初期に在学中から参加している最古参メンバーの一人。Ruby on Rails、PHP、Androidアプリ、Windows/Macアプリ、超縦書の開発などを気まぐれにやる。軽度の資格マニアで、情報処理技術者試験(16区分17回 + 情報処理安全確保支援士試験)、技術士(情報工学部門)、Ruby Programmer Gold、AWSソリューションアーキテクト(アソシエイト)、日商簿記2級、漢検準1級などを保有。

babaの書いた記事

夏のTechRachoフェア2019

週刊Railsウォッチ

インフラ

ActiveSupport探訪シリーズ