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

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

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

加藤 正人

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

PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)

2013/02/09

PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)

 

CakePHP で画像のアップロードには Szajbe氏の UploadPack をよく使っている。手軽で簡単・便利なのだが、先日再びちょっとしたハマりがあったのでレポート。

今回は画像を保持するテーブルの制限で、primary_key フィールドの名称が 'id' ではなく 'item_base_id' という名称になっていた。

このテーブルに対応するモデルにビヘイビアとして UploadPack.Upload を指定すると、保存は意図したとおりに動作するのだが、ビューで UploadPack が処理した画像の URL を取得すべく

	$this->Upload->url($data, 'ItemBase.picture1', array('style' => 'thumb'));

のようにすると、常にその時点での表示ページの URL が返されてしまい、画像への URL にならない。

困ったときはソースを見よう、ということで UploadPack/View/Helper/UploadHelper.php を見てみると、Upload::url() は以下のようになっている。

    public function url($data, $field, $options = array())
    {
        $options += array('style' => 'original', 'urlize' => true);
        list($model, $field) = explode('.', $field);
        if(is_array($data))
        {
            if(isset($data[$model]))
            {
                if(isset($data[$model]['id']))
                {
                    $id = $data[$model]['id'];
                    $filename = $data[$model][$field.'_file_name'];
                }
            }
            elseif(isset($data['id']))
            {
                $id = $data['id'];
                $filename = $data[$field.'_file_name'];
            }
        }

        if(isset($id) && !empty($filename))
        {
            $settings = UploadBehavior::interpolate($model, $id, $field, $filename, $options['style'], array('webroot' => ''));
            $url = isset($settings['url']) ? $settings['url'] : $settings['path'];
        }
        else
        {
            $settings = UploadBehavior::interpolate($model, null, $field, null, $options['style'], array('webroot' => ''));
            $url = isset($settings['default_url']) ? $settings['default_url'] : null;
        }

        return $options['urlize'] ? $this->Html->url($url) : $url;

        // 以下省略

つまり、当該モデルの主キーとして常に 'id' を使用しているが、今回のモデルには 'id' というフィールドが無いため $url は NULL となり、最後の return で Html ヘルパーの url が呼ばれてデフォルト値で現在の URL が返ってきてしまっているということだった。

モデル定義で primaryKey を指定しても無視しているわけだ。

とりあえず今回使用するモデル ItemBase には id というフィールドは存在していないので、url() メソッドにデータを与える前に $data['ItemBase']['id'] = $data['ItemBase']['item_base_id']; とすることで対応はできるが、本来なら UploadPack 側で primaryKey を見るべきだと思う。

関連タグ: CakePHP2  UploadPack 

関連エントリー