DEVELOPERS BLOGデベロッパーズブログ

  1. HOME > 
  2. 加藤 正人のデベロッパーズブログ > 
  3. UploadPack で四苦Hack

加藤 正人のデベロッパーズブログ

加藤 正人

氏名
加藤 正人
役職
多分SE
血液型
秘密
出没
美味しいもののあるところ
特色
タヒチ大好き。ちょいメタボ。

加藤 正人

2012/11/12

UploadPack で四苦Hack

 

CakePHP で開発する場合のファイルアップロード処理には、Michał Szajbe 氏の「UploadPack」を利用しているのだが、9月末ごろ作成したシステムでは何故か既存画像が消えるという事件があった。データベースフィールドへの登録データの消失だけでなく、そのフィールドに関連付けられたファイルシステム上の画像も消えてしまうというものだ。

新規登録時には問題なく登録できるのだが、登録済みデータの画像をいくつか UploadPack で更新するとそれ以外の画像が消えてしまうのだ。

こんな現象はこれまで発生していなかったのだが、公式サイトにも何も記載されていなかった。

最初は CakePHP 2.x の Strict 問題か、とも思ってソースをハックしてみたのだが、特に怪しい個所も見当たらない。

2、3日悩んだ挙句仕方がないので画像の保持をするロジックを組み込んで UploadPack で処理後編集対象外のファイルをファイルシステム上でリカバリする仕組みを作り始めたのだが、改めて UploadPack の公式サイトをアクセスしたら「dont remove files on every save. [fixes #16]」というバグフィックスが。

結局、これは8月末にリリースした「レコード全体を削除しなくてもファイルを削除できるようにする」機能のコードに誤りがあり、UploadBehavior.php 内で「ファイルの削除」かどうかを「ファイルアップロード対象フィールドがフォームデータ上で空欄かどうか」で判定してしまうというバグを入れ込んでしまったということらしい。

これに対応した v0.6.2 がリリースされたので、プライベートパッチは放棄してこちらを利用することですんなり現象は解決した。

過去半年以上メンテナンスが無かったので安定していると判断して (バージョンを確認せず) 利用していたのだが、やはりリリースノートや改訂履歴はきちんと内容を確認しないとダメ、ということが身に染みた一件だった。

関連タグ: CakePHP2  UploadPack 

関連エントリー

CakePHP のレンダリング結果を保存したい

CakePHP 2.x の Cookie と js.cookie.js

時刻入力用 jQuery Plugin TimePicki の不具合調整

CakePHP プラグインで HTTPS 判定

作業用モデルビヘイビア

CakePHP のバリデーション時に状況に応じてバリデーションルールを変更する

CsvLoader ビヘイビアを使って CSV を一発でロードする Cake Shell

CakePHP の Security コンポーネント、ベーシック認証、CGI

形態素解析システム MeCab (めかぶ) を CakePHP から利用する

Google APIs Client Library を CakePHP から利用する

分数電卓を作ってみる・その2

分数電卓を作ってみる・その1

CsvLoaderBhavior - CSV データを CakePHP で扱うための一手法・その2

 CsvLoaderBhavior - CSV データを CakePHP で扱うための一手法

CakePHP でストアドファンクション

テキストフィールドを CSV として処理する CakePHP ビヘイビア・補足

テキストフィールドを CSV として処理する CakePHP ビヘイビア・その2

テキストフィールドを CSV として処理する CakePHP ビヘイビア・その1

Google Maps で郵便番号⇒住所変換・その2

テキストを自動整形する簡易 CakePHP ヘルパー

Google Chart へのアクセスをヘルパーで実装してみる【その2】

Google Chart へのアクセスをヘルパーで実装してみる【その1】

Google reCAPTCHA を使いやすくする

駅データ.jp のデータを CakePHP から使う

CakePHP の小ネタ

UploadPack を Exif Orientation 対応にする

作業用テーブル処理を再利用可能なツール化してみる・その1

クリックイベントが2回実行される?!

CakePHP のフォームで required・その2

CakePHP の Paginator の sort() で昇順ソート時に NULL 値を最後にしたい

CakePHP のフォームで required

UploadPack のヘルパーメソッド名称が変わっていた

CakePHP 2.x の PaginatorHelper::sort の不思議

UploadPack で四苦八苦・再び

CakePHP で四苦八苦 - あるフィールドにだけ値が書き込まれない

UploadPack で四苦Hack その後

CakePHP の小ネタ

CakePHP v2 のエラー処理

IE10 と CKEditor

2013/03/23
IE10 と CKEditor

UploadPack で四苦Hack・その2

Paginator で見かけの URL を使用する方法

「Notes プラグインが見つかりません」

CakePHP v2 で HTTP エラー画面をカスタマイズする

PHP 5.4 と CakePHP 2.x