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

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

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

加藤 正人

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

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

2013/06/22

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

 

UploadPack には、画像を保持するテーブルの主キーが 'id' でないと正しく動作しないという不具合がある。

これに対応する方法を思いついたのでメモ。

UploadPack/View/Helper/UploadHelper.php の url() パブリックメソッドで以下のようにして関連付けられているモデルの主キー名を取得することで解決する。

	function url($data, $field, $options = array())
	{
		$options += array('style' => 'original', 'urlize' => true);
		list($model, $field) = explode('.', $field);

		$model_object =& ClassRegistry::getObject($model);	// モデルをロードし、primaryKey 情報を得る
		$id_field = $model_object->primaryKey;

		if(is_array($data))
		{
			if(isset($data[$model]))
			{
//				if(isset($data[$model]['id']))
				if(isset($data[$model][$id_field]))
				{
//					$id = $data[$model]['id'];
					$id = $data[$model][$id_field];
					$filename = $data[$model][$field.'_file_name'];
				}
			}
//			elseif(isset($data['id']))
			elseif(isset($data[$id_field]))
			{
//				$id = $data['id'];
				$id = $data[$id_field];
				$filename = $data[$field.'_file_name'];
			}
		}

		if(isset($id) && isset($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;
	}
関連タグ: CakePHP2  UploadPack 

関連エントリー