2.5 移行ガイド
CakePHP 2.5 は、2.4 の API の完全上位互換です。 このページでは、2.5 の変更と改善についてのアウトラインを紹介します。
キャッシュ
Memcachedアダプターが新しく追加されました。新しいアダプターは、 ext/memcache の代わりに ext/memcached を使用します。パフォーマンスの向上と 永続的なコネクションの共有をサポートします。Memcachedアダプターの追加に伴いMemcacheアダプターは非推奨になりました。Cache::remember()が追加されました。Cache::config()は、RedisEngine使用の際、 非標準のデータベース番号のためにdatabaseキーを許可するようになりました。
コンソール
SchemaShell
- サブコマンド
createとupdateにyesオプションが追加されました。yesオプションは、対話的な質問をスキップするために強制的に yes で返します。
CompletionShell
- CompletionShell が追加されました。 bash や zsh のようなシェル環境上のための自動補完ライブラリ作成を補助することが狙いです。 CakePHP にはシェルスクリプトは含まれていませんが、基礎となるツールを用意しました。
コントローラ
AuthComponent
loggedIn()が非推奨になりました。 3.0 で削除されます。ajaxLoginを使用していてユーザーが未認証の場合、 AuthComponent は200の代わりに403ステータスコードを返すようになりました。
CookieComponent
CookieComponentはSecurityの変更に伴い AES-256 暗号を使用できます。CookieComponent::type()に 'aes' を指定することで有効になります。
RequestHandlerComponent
RequestHandlerComponent::renderAs()はController::$extを 設定しなくなりました。ビューが非標準の拡張子の場合、問題が発生していました。
AclComponent
- ACL ノード参照失敗は、直接ログ出力されます。
trigger_error()の呼び出しは削除されました。
Scaffold
- 動的な Scaffold は非推奨になりました。3.0 で削除されます。
コア
App
App::pluginPath()は非推奨になりました。代わりにCakePlugin::path()を使用してください。
CakePlugin
CakePlugin::loadAll()は、直感通りにデフォルト設定とプラグイン固有のオプションをマージします。詳しくは、テストケースを参照してください。
イベント
EventManager
グローバルなマネージャに紐づくイベントは、ローカルなマネージャーに紐づくイベントと共に、優先順位に従って実行されます。 今までのリリースでは、異なる順番で実行されていました。 全てのグローバルなリスナーが呼ばれたあとにインスタンスリスナーが実行されていましたが、今後は2つのリスナーの集まりを優先順位に従って1つのリスナーのリストに結合した後、実行します。 優先順位が高いグローバルなリスナーは、インスタンスリスナーの前に実行されます。
I18n
I18nクラスにいくつかの定数が追加されました。これらの定数は、 読みやすいようにハードコードされた整数を置き換えるものです。 例:I18n::LC_MESSAGES。
モデル
- データソースによって符号なし整数がサポートされました (MySQL)。 スキーマやフィクスチャのファイル中で
unsiginedオプションを true に 設定すると、この機能が有効になります。 - クエリ中に含まれる JOIN は、 アソシエーションからの JOIN の 後に 追加されます。 これにより、自動生成されたアソシエーションに依存するテーブル結合を容易にします。
ネットワーク
CakeEmail
- CakeEmail で扱うメールアドレスは、デフォルトで
filter_varで検証されます。 これは、root@localhostのようなメールアドレスを許可するためにメールアドレス規則を緩和します。 - email の設定配列で、
templateキーを指定していなくてもlayoutキーを指定できるようになりました。
CakeRequest
CakeRequest::addDetector()は、パラメータベースの検出器を作成するときに、有効なオプションの配列を受け入れるoptionsをサポートします。CakeRequest::onlyAllow()が非推奨になりました。 代わりに同等の機能を持つCakeRequest::allowMethod()メソッドが追加されました。
CakeSession
- セッションが空の場合、セッションは開始されなくなります。 もしセッションクッキーが見つからない時、書込み操作が完了するまではセッションは開始されません。
ルーティング
Router
Router::mapResources()は、$options引数の中でconnectOptionsキーを許可するようになりました。 詳しくは、カスタムRESTルーティング を参照してください。
ユーティリティ
Debugger
Debugger::dump()とDebugger::log()は、$depthパラメータをサポートします。 これの新しいパラメータは、より深くネストされたオブジェクト構造を容易に出力できるようになります。
Hash
Hash::insert()とHash::remove()は、マッチャー表現によるパスの指定をサポートしました。
File
File:replaceText()が追加されました。このメソッドは、str_replaceを使ってファイル中のテキストを簡単に置き換えることが出来ます。
Folder
Folder::addPathElement()は、$elementパラメータを配列として受け取るようになりました。
Security
Security::encrypt()とSecurity::decrypt()が追加されました。 これらのメソッドは、AES-256 共通鍵暗号を利用するためのとてもシンプルなAPIです。 これらはcipher()やrijndael()メソッドを考慮して使用されるべきです。
Validation
Validation::inList()とValidation::multiple()の 第三引数は、 $strict から $caseInsensitive に修正されました。 $strict は、間違った動作をしていて誤解されやすいため、廃止になりました。 今は、大文字と小文字を区別せずに比較するために、このパラメータに true を設定します。 デフォルト値は false で、今までのように大文字と小文字を区別して値やリストを比較します。Validation::mimeType()の$mimeTypesパラメータは、正規表現が使用できます。 また、$mimeTypesが配列の場合、配列の値は小文字になります。
ロギング
FileLog
- CakeLog は、自動設定されなくなりました。結果として、出力先が未設定ならログファイルは自動的に作成されなくなりました。 もし、全てのタイプやレベルのログを出力させたいなら、少なくとも1つのデフォルトエンジンを設定する必要があります。
エラー
ExceptionRenderer
ExceptionRenderer は、エラーテンプレートに "code"、"message"、"url" 変数が設定されます。 "name" 変数は非推奨になりましたが、まだ使用可能です。これら変数は、全てのエラーテンプレートにわたって一様に適用されます。
テスト
- フィクスチャファイルはサブディレクトリに配置できるようになりました。
.の後にディレクトリ名を加えることで、サブディレクトリ内のフィクスチャを利用できます。 例えば、 app.my_dir/article はApp/Test/Fixture/my_dir/ArticleFixtureを読み込みます。 - フィクスチャは、
$canUseMemoryに false を設定することで、MySQL の MEMORY ストレージエンジンの使用を無効にすることが出来ます。
ビュー
View
$title_for_layoutは非推奨になりました。代わりに$this->fetch('title');と$this->assign('title', 'あなたのページタイトル');を使用してください。View::get()は、第二引数にデフォルト値を指定できるようになりました。
FormHelper
- FormHelper は、
binaryフィールドタイプのためのファイル入力フォームを生成します。 FormHelper::end()は、第二引数が追加されました。このパラメータは、 SecurityComponent と連携してフォームの安全を保つためのフィールドに新たな属性を追加することができます。FormHelper::end()とFormHelper::secure()は、 生成された hidden input の属性を追加オプションと置き換えることが出来るようになりました。 これは、 HTML5 のform属性を使用したい時に便利です。FormHelper::postLink()は、リンクとして返すの代わりに生成された form タグをバッファリングすることが出来るようになりました。これは、折り重なった form タグを避けるのに役立ちます。
PaginationHelper
PaginatorHelper::sort()は、 デフォルトのソート順のみでページをソートするリンクを生成するためにlockオプションが追加されました。
ScaffoldView
- 動的なスキャフォールドは非推奨になりました。 3.0 で削除されます。