DEVELOPERS BLOGデベロッパーズブログ
CakePHP 2.x で設定したクッキーを JavaScript (js.cookie.js) で処理しようとして問題にぶち当たった。
CakePHP 2.x では Cookie 名 (既定値は 'CakeCookie') に対しキーを配列のように付与して、CakeCookie[key] という形式でアクセスする。一方 js.cookie.js では [ および ] は%表記として扱う。
このため、Cookies.get('CakeCookie[key]') で CakePHP で設定したクッキーは読み取れるのだが、書き込み時に Cookies.set('CakeCookie[key]', 'abc') のようにすると CakeCookie%5Bkey%5D という名称でクッキーが書き込まれてしまい、CakeCookie[key] とは別のものとなってしまう。
Cookie 仕様としては [ や ] はエンコードするのが正しいようなので、これらを直接指定するのは CakePHP 2.x の不具合のようだ。
対応は CakePHP のコード修正よりも js.cookie.js の方がソース量が小さく、他への影響が少ないので js.cookie.js で対応することにする。
具体的には、js.cookie.js の「書き込みロジック」部分 (先頭から78行目あたり) で
key = key.replace(/%(23|24|26|2B|5E|60|7C)/g, decodeURIComponent);
としているところを
key = key.replace(/%(23|24|26|2B|5B|5D|5E|60|7C)/g, decodeURIComponent);
として、5B ([) および 5D (]) を追加してこれらを URI エンコードしないようにして対応する。
この記事は加藤 正人さんが書いています!
- 氏名
- 加藤 正人
- 役職
- 多分SE
- 血液型
- 秘密
- 出没
- 美味しいもののあるところ
- 特色
- タヒチ大好き。ちょいメタボ。
- 2020/12/15
- CakePHP3 のリダイレクトがうまく行かない例
- 2020/11/12
- Apache Bench
- 2020/10/05
- PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)
2020/12/15
2020/11/12
2020/10/05
2020/09/11
2020/08/03