action(); $this->sendResponse(); } /** * Page のAction. * * @return void */ function action() { $objFormParam = new SC_FormParam_Ex(); $this->lfInitParam($objFormParam); $objFormParam->setParam($_GET); $arrForm = $objFormParam->getHashArray(); $file = NO_IMAGE_REALFILE; // NO_IMAGE_REALFILE以外のファイル名が渡された場合、ファイル名のチェックを行う if (strlen($arrForm['image']) >= 1 && $arrForm['image'] !== NO_IMAGE_REALFILE) { // ファイル名が正しく、ファイルが存在する場合だけ、$fileを設定 if (!$this->lfCheckFileName()) { GC_Utils_Ex::gfPrintLog('invalid access :resize_image.php image=' . $arrForm['image']); } elseif (file_exists(IMAGE_SAVE_REALDIR . $arrForm['image'])) { $file = IMAGE_SAVE_REALDIR . $arrForm['image']; } } // リサイズ画像の出力 $this->lfOutputImage($file, $arrForm['width'], $arrForm['height']); } /** * デストラクタ. * * @return void */ function destroy() { parent::destroy(); } function lfInitParam(&$objFormParam) { $objFormParam->addParam('画像ファイル名', 'image', STEXT_LEN, 'a', array('MAX_LENGTH_CHECK')); $objFormParam->addParam('画像の幅', 'width', STEXT_LEN, 'n', array('NUM_CHECK')); $objFormParam->addParam('画像の高さ', 'width', STEXT_LEN, 'n', array('NUM_CHECK')); } /** * ファイル名の形式をチェック. * * @return boolean 正常な形式:true 不正な形式:false */ function lfCheckFileName() { //$pattern = '|^[0-9]+_[0-9a-z]+\.[a-z]{3}$|'; $pattern = '|\./|'; $file = trim($_GET['image']); if (preg_match_all($pattern, $file, $matches)) { return false; } else { return true; } } /** * 画像の出力 * * @param string $file 画像ファイル名 * @param integer $width 画像の幅 * @param integer $height 画像の高さ * * @return void */ function lfOutputImage($file, $width, $height) { $objThumb = new gdthumb(); $objThumb->Main($file, $width, $height, '', true); } }