source: branches/version-2_13-dev/data/class/SC_UploadFile.php @ 23482

Revision 23482, 20.1 KB checked in by shutta, 8 years ago (diff)

#2545 ファイルアップロード時のエラーメッセージが不適切
何もファイルを指定せずにアップロードした場合のエラーメッセージを追加。

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2013 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24/* アップロードファイル管理クラス */
25class SC_UploadFile
26{
27    public $temp_dir;
28    public $save_dir;
29
30    /** ファイルinputタグのname */
31    public $keyname = array();
32
33    /** 横サイズ */
34    public $width = array();
35
36    /** 縦サイズ */
37    public $height = array();
38
39    /** 指定する拡張子 */
40    public $arrExt = array();
41
42    /** 保存されたファイル名 */
43    public $temp_file = array();
44
45    /** DBから読み出したファイル名 */
46    public $save_file = array();
47
48    /** 項目名 */
49    public $disp_name = array();
50
51    /** 制限サイズ */
52    public $size = array();
53
54    /** 必須の場合:true */
55    public $necessary = array();
56
57    /** 画像の場合:true */
58    public $image = array();
59
60    // ファイル管理クラス
61    public function __construct($temp_dir, $save_dir)
62    {
63        $this->temp_dir = rtrim($temp_dir, '/') . '/';
64        $this->save_dir = rtrim($save_dir, '/') . '/';
65        $this->file_max = 0;
66    }
67
68    // ファイル情報追加
69    public function addFile($disp_name, $keyname, $arrExt, $size, $necessary=false, $width=0, $height=0, $image=true)
70    {
71        $this->disp_name[] = $disp_name;
72        $this->keyname[] = $keyname;
73        $this->width[] = $width;
74        $this->height[] = $height;
75        $this->arrExt[] = $arrExt;
76        $this->size[] = $size;
77        $this->necessary[] = $necessary;
78        $this->image[] = $image;
79    }
80    // サムネイル画像の作成
81    public function makeThumb($src_file, $width, $height, $dst_file)
82    {
83        $objThumb = new gdthumb();
84        $ret = $objThumb->Main($src_file, $width, $height, $dst_file);
85
86        if ($ret[0] != 1) {
87            // エラーメッセージの表示
88            echo $ret[1];
89            exit;
90        }
91
92        return basename($ret[1]);
93    }
94
95    // アップロードされたファイルを保存する。
96    public function makeTempFile($keyname, $rename = IMAGE_RENAME)
97    {
98        $objErr = new SC_CheckError_Ex();
99        $cnt = 0;
100        $arrKeyname = array_flip($this->keyname);
101
102        if ($_FILES[$keyname]['error'] === UPLOAD_ERR_OK) {
103            foreach ($this->keyname as $val) {
104                // 一致したキーのファイルに情報を保存する。
105                if ($val == $keyname) {
106                    // 拡張子チェック
107                    $objErr->doFunc(array($this->disp_name[$cnt], $keyname, $this->arrExt[$cnt]), array('FILE_EXT_CHECK'));
108                    // ファイルサイズチェック
109                    $objErr->doFunc(array($this->disp_name[$cnt], $keyname, $this->size[$cnt]), array('FILE_SIZE_CHECK'));
110                    // エラーがない場合
111                    if (!isset($objErr->arrErr[$keyname])) {
112                        // 画像ファイルの場合
113                        if ($this->image[$cnt]) {
114                            // 保存用の画像名を取得する
115                            $dst_file = $this->lfGetTmpImageName($rename, $keyname);
116                            $this->temp_file[$cnt] = $this->makeThumb($_FILES[$keyname]['tmp_name'], $this->width[$cnt], $this->height[$cnt], $dst_file);
117                        // 画像ファイル以外の場合
118                        } else {
119                            // 一意なファイル名を作成する。
120                            if ($rename) {
121                                $uniqname = date('mdHi') . '_' . uniqid('').'.';
122                                $this->temp_file[$cnt] = preg_replace("/^.*\./", $uniqname, $_FILES[$keyname]['name']);
123                            } else {
124                                $this->temp_file[$cnt] = $_FILES[$keyname]['name'];
125                            }
126                            if (move_uploaded_file($_FILES[$keyname]['tmp_name'], $this->temp_dir . $this->temp_file[$cnt])) {
127                                GC_Utils_Ex::gfPrintLog($_FILES[$keyname]['name'].' -> '. $this->temp_dir . $this->temp_file[$cnt]);
128                            } else {
129                                $objErr->arrErr[$keyname] = '※ ファイルのアップロードに失敗しました。<br />';
130                                GC_Utils_Ex::gfPrintLog('File Upload Error!: ' . $_FILES[$keyname]['name'].' -> '. $this->temp_dir . $this->temp_file[$cnt]);
131                            }
132                        }
133                    }
134                }
135                $cnt++;
136            }
137        } elseif ($_FILES[$keyname]['error'] === UPLOAD_ERR_NO_FILE) {
138            $objErr->arrErr[$keyname] .= '※ '
139                . $this->disp_name[$arrKeyname[$keyname]]
140                . 'が選択されていません。'
141                . '<br />';
142        } else {
143            $objErr->arrErr[$keyname] .= '※ '
144                . $this->disp_name[$arrKeyname[$keyname]]
145                . 'のアップロードに失敗しました。'
146                . 'エラーコードは[' . $_FILES[$keyname]['error'] . ']です。'
147                . '<br />';
148        }
149
150        return $objErr->arrErr[$keyname];
151    }
152
153    // アップロードされたダウンロードファイルを保存する。
154    public function makeTempDownFile($keyname='down_file')
155    {
156        $objErr = new SC_CheckError_Ex();
157        $cnt = 0;
158        $arrKeyname = array_flip($this->keyname);
159        if (!($_FILES[$keyname]['size'] > 0)) {
160            $objErr->arrErr[$keyname] = '※ ' . $this->disp_name[$arrKeyname[$keyname]] . 'がアップロードされていません。(ファイルがアップロードできない場合は、.htaccessファイルのphp_value upload_max_filesizeを調整してください)<br />';
161        } else {
162            foreach ($this->keyname as $val) {
163                // 一致したキーのファイルに情報を保存する。
164                if ($val == $keyname) {
165                    // 拡張子チェック
166                    $objErr->doFunc(array($this->disp_name[$cnt], $keyname, $this->arrExt[$cnt]), array('FILE_EXT_CHECK'));
167                    // ファイルサイズチェック
168                    $objErr->doFunc(array($this->disp_name[$cnt], $keyname, $this->size[$cnt]), array('FILE_SIZE_CHECK'));
169                    // エラーがない場合
170                    if (!isset($objErr->arrErr[$keyname])) {
171                        // 一意なファイル名を作成する。
172                        $uniqname = date('mdHi') . '_' . uniqid('').'.';
173                        $this->temp_file[$cnt] = preg_replace("/^.*\./", $uniqname, $_FILES[$keyname]['name']);
174                        $result  = copy($_FILES[$keyname]['tmp_name'], $this->temp_dir . $this->temp_file[$cnt]);
175                        GC_Utils_Ex::gfPrintLog($result.' -> '. $this->temp_dir . $this->temp_file[$cnt]);
176                        SC_Utils_Ex::extendTimeOut();
177                    }
178                }
179                $cnt++;
180            }
181        }
182
183        return $objErr->arrErr[$keyname];
184    }
185
186    // 画像を削除する。
187    public function deleteFile($keyname)
188    {
189        $objImage = new SC_Image_Ex($this->temp_dir);
190        $cnt = 0;
191        foreach ($this->keyname as $val) {
192            if ($val == $keyname) {
193                // 一時ファイルの場合削除する。
194                if ($this->temp_file[$cnt] != '') {
195                    $objImage->deleteImage($this->temp_file[$cnt], $this->temp_dir);
196                }
197                $this->temp_file[$cnt] = '';
198                $this->save_file[$cnt] = '';
199            }
200            $cnt++;
201        }
202    }
203
204    // 画像を削除する。
205    public function deleteKikakuFile($keyname)
206    {
207        $objImage = new SC_Image_Ex($this->temp_dir);
208        $cnt = 0;
209        foreach ($this->keyname as $val) {
210            if ($val == $keyname) {
211                // 一時ファイルの場合削除する。
212                if ($this->temp_file[$cnt] != '') {
213                    $objImage->deleteImage($this->temp_file[$cnt], $this->temp_dir);
214                }
215                $this->temp_file[$cnt] = '';
216                //$this->save_file[$cnt] = '';
217            }
218            $cnt++;
219        }
220    }
221
222    // 一時ファイルパスを取得する。
223    public function getTempFilePath($keyname)
224    {
225        $cnt = 0;
226        $filepath = '';
227        foreach ($this->keyname as $val) {
228            if ($val == $keyname) {
229                if ($this->temp_file[$cnt] != '') {
230                    $filepath = $this->temp_dir . $this->temp_file[$cnt];
231                }
232            }
233            $cnt++;
234        }
235
236        return $filepath;
237    }
238
239    // 一時ファイルを保存ディレクトリに移す
240    public function moveTempFile()
241    {
242        $objImage = new SC_Image_Ex($this->temp_dir);
243
244        for ($cnt = 0; $cnt < count($this->keyname); $cnt++) {
245            if (isset($this->temp_file[$cnt]) && $this->temp_file[$cnt] != '') {
246                $objImage->moveTempImage($this->temp_file[$cnt], $this->save_dir);
247
248                // すでに保存ファイルがあった場合は削除する。
249                if (isset($this->save_file[$cnt])
250                    && $this->save_file[$cnt] != ''
251                    && !preg_match('|^sub/|', $this->save_file[$cnt])
252                ) {
253                    $objImage->deleteImage($this->save_file[$cnt], $this->save_dir);
254                }
255            }
256        }
257    }
258
259    // ダウンロード一時ファイルを保存ディレクトリに移す
260    public function moveTempDownFile()
261    {
262        $objImage = new SC_Image_Ex($this->temp_dir);
263        for ($cnt = 0; $cnt < count($this->keyname); $cnt++) {
264            if (isset($this->temp_file[$cnt]) && $this->temp_file[$cnt] != '') {
265                $objImage->moveTempImage($this->temp_file[$cnt], $this->save_dir);
266                // すでに保存ファイルがあった場合は削除する。
267                if (isset($this->save_file[$cnt])
268                    && $this->save_file[$cnt] != ''
269                    && !preg_match('|^sub/|', $this->save_file[$cnt])
270                ) {
271                    $objImage->deleteImage($this->save_file[$cnt], $this->save_dir);
272                }
273            }
274        }
275    }
276
277    // HIDDEN用のファイル名配列を返す
278    public function getHiddenFileList()
279    {
280        $cnt = 0;
281        $arrRet = array();
282        foreach ($this->keyname as $val) {
283            if (isset($this->temp_file[$cnt])) {
284                $arrRet['temp_' . $val] = $this->temp_file[$cnt];
285            }
286            if (isset($this->save_file[$cnt]) && $this->save_file[$cnt] != '') {
287                $arrRet['save_' . $val] = $this->save_file[$cnt];
288            }
289            $cnt++;
290        }
291
292        return $arrRet;
293    }
294
295    // HIDDENで送られてきたファイル名を取得する
296    public function setHiddenFileList($arrPOST)
297    {
298        $cnt = 0;
299        foreach ($this->keyname as $val) {
300            $key = 'temp_' . $val;
301            if (isset($arrPOST[$key]) && !empty($arrPOST[$key])) {
302                $this->temp_file[$cnt] = $arrPOST[$key];
303            }
304            $key = 'save_' . $val;
305            if (isset($arrPOST[$key]) && !empty($arrPOST[$key])) {
306                $this->save_file[$cnt] = $arrPOST[$key];
307            }
308            $cnt++;
309        }
310    }
311
312    public function setHiddenKikakuFileList($arrPOST)
313    {
314        $cnt = 0;
315        foreach ($this->keyname as $val) {
316            $key = 'temp_' . $val;
317            if (isset($arrPOST[$key])) {
318                $this->temp_file[$cnt] = $arrPOST[$key];
319            }
320            $key = 'save_' . $val;
321            if (isset($arrPOST[$key]) && !empty($arrPOST[$key])) {
322                $this->save_file[$cnt] = $arrPOST[$key];
323            }
324            $cnt++;
325        }
326    }
327
328    // フォームに渡す用のファイル情報配列を返す
329    public function getFormFileList($temp_url, $save_url, $real_size = false)
330    {
331        $arrRet = array();
332        $cnt = 0;
333        foreach ($this->keyname as $val) {
334            if (isset($this->temp_file[$cnt]) && $this->temp_file[$cnt] != '') {
335                // パスのスラッシュ/が連続しないようにする。
336                $arrRet[$val]['filepath'] = rtrim($temp_url, '/') . '/' . $this->temp_file[$cnt];
337
338                $arrRet[$val]['real_filepath'] = $this->temp_dir . $this->temp_file[$cnt];
339            } elseif (isset($this->save_file[$cnt]) && $this->save_file[$cnt] != '') {
340                // パスのスラッシュ/が連続しないようにする。
341                $arrRet[$val]['filepath'] = rtrim($save_url, '/') . '/' . $this->save_file[$cnt];
342
343                $arrRet[$val]['real_filepath'] = $this->save_dir . $this->save_file[$cnt];
344            }
345            if (isset($arrRet[$val]['filepath']) && !empty($arrRet[$val]['filepath'])) {
346                if ($real_size) {
347                    if (is_file($arrRet[$val]['real_filepath'])) {
348                        list($width, $height) = getimagesize($arrRet[$val]['real_filepath']);
349                    }
350                    // ファイル横幅
351                    $arrRet[$val]['width'] = $width;
352                    // ファイル縦幅
353                    $arrRet[$val]['height'] = $height;
354                } else {
355                    // ファイル横幅
356                    $arrRet[$val]['width'] = $this->width[$cnt];
357                    // ファイル縦幅
358                    $arrRet[$val]['height'] = $this->height[$cnt];
359                }
360                // 表示名
361                $arrRet[$val]['disp_name'] = $this->disp_name[$cnt];
362            }
363            $cnt++;
364        }
365
366        return $arrRet;
367    }
368
369    // フォームに渡す用のダウンロードファイル情報を返す
370    public function getFormDownFile()
371    {
372        $arrRet = '';
373        for ($cnt = 0; $cnt < count($this->keyname); $cnt++) {
374            if (isset($this->temp_file[$cnt]) && $this->temp_file[$cnt] != '') {
375                $arrRet = $this->temp_file[$cnt];
376            } elseif (isset($this->save_file[$cnt]) && $this->save_file[$cnt] != '') {
377                $arrRet = $this->save_file[$cnt];
378            }
379        }
380
381        return $arrRet;
382    }
383    public function getFormKikakuDownFile()
384    {
385        $arrRet = array();
386        $cnt = 0;
387        foreach ($this->keyname as $val) {
388            if (isset($this->temp_file[$cnt])) {
389                $arrRet[$val] = $this->temp_file[$cnt];
390            } elseif (isset($this->save_file[$cnt]) && $this->save_file[$cnt] != '') {
391                $arrRet[$val] = $this->save_file[$cnt];
392            }
393            $cnt++;
394        }
395
396        return $arrRet;
397    }
398
399    // DB保存用のファイル名配列を返す
400    public function getDBFileList()
401    {
402        $cnt = 0;
403        $dbFileList = array();
404        foreach ($this->keyname as $val) {
405            if (isset($this->temp_file[$cnt]) && $this->temp_file[$cnt] != '') {
406                $dbFileList[$val] = $this->temp_file[$cnt];
407            } else {
408                $dbFileList[$val] = isset($this->save_file[$cnt]) ? $this->save_file[$cnt] : '';
409            }
410            $cnt++;
411        }
412
413        return $dbFileList;
414    }
415
416    // DBで保存されたファイル名配列をセットする
417    public function setDBFileList($arrVal)
418    {
419        $cnt = 0;
420        foreach ($this->keyname as $val) {
421            if (isset($arrVal[$val]) && $arrVal[$val] != '') {
422                $this->save_file[$cnt] = $arrVal[$val];
423            }
424            $cnt++;
425        }
426    }
427
428    // DBで保存されたダウンロードファイル名をセットする
429    public function setDBDownFile($arrVal)
430    {
431        if (isset($arrVal['down_realfilename']) && $arrVal['down_realfilename'] != '') {
432            $this->save_file[0] = $arrVal['down_realfilename'];
433        }
434    }
435
436    // DBで保存されたダウンロードファイル名をセットする(setDBDownFileと統合予定)
437    public function setPostFileList($arrPost)
438    {
439        for ($cnt = 0;$cnt < count($this->keyname); $cnt++) {
440            if (isset($arrPost['temp_down_realfilename:' . ($cnt+1)])) {
441                $this->temp_file[$cnt] = $arrPost['temp_down_realfilename:' . ($cnt+1)];
442            }
443        }
444    }
445
446    // 画像をセットする
447    public function setDBImageList($arrVal)
448    {
449        $cnt = 0;
450        foreach ($this->keyname as $val) {
451            if ($arrVal[$val] != '' && $val == 'tv_products_image') {
452                $this->save_file[$cnt] = $arrVal[$val];
453            }
454            $cnt++;
455        }
456    }
457
458    // DB上のファイルの内削除要求があったファイルを削除する。
459    public function deleteDBFile($arrVal)
460    {
461        $objImage = new SC_Image_Ex($this->temp_dir);
462        $cnt = 0;
463        foreach ($this->keyname as $val) {
464            if ($arrVal[$val] != '') {
465                if ($this->save_file[$cnt] == '' && !preg_match('|^sub/|', $arrVal[$val])) {
466                    $objImage->deleteImage($arrVal[$val], $this->save_dir);
467                }
468            }
469            $cnt++;
470        }
471    }
472
473    // DB上のダウンロードファイルの内削除要求があったファイルを削除する。
474    public function deleteDBDownFile($arrVal)
475    {
476        $objImage = new SC_Image_Ex($this->temp_dir);
477        $cnt = 0;
478        if ($arrVal['down_realfilename'] != '') {
479            if ($this->save_file[$cnt] == '' && !preg_match('|^sub/|', $arrVal['down_realfilename'])) {
480                $objImage->deleteImage($arrVal['down_realfilename'], $this->save_dir);
481            }
482        }
483    }
484
485    // 必須判定
486    public function checkExists($keyname = '')
487    {
488        $cnt = 0;
489        $arrRet = array();
490        foreach ($this->keyname as $val) {
491            if ($val == $keyname || $keyname == '') {
492                // 必須であればエラーチェック
493                if ($this->necessary[$cnt] == true) {
494                    if (!isset($this->save_file[$cnt])) $this->save_file[$cnt] = '';
495                    if (!isset($this->temp_file[$cnt])) $this->temp_file[$cnt] = '';
496                    if ($this->save_file[$cnt] == ''
497                        && $this->temp_file[$cnt] == ''
498                    ) {
499                        $arrRet[$val] = '※ ' . $this->disp_name[$cnt] . 'がアップロードされていません。<br>';
500                    }
501                }
502            }
503            $cnt++;
504        }
505
506        return $arrRet;
507    }
508
509    // 拡大率を指定して画像保存
510    public function saveResizeImage($keyname, $to_w, $to_h)
511    {
512        $path = '';
513
514        // keynameの添付ファイルを取得
515        $arrImageKey = array_flip($this->keyname);
516        $file = $this->temp_file[$arrImageKey[$keyname]];
517        $filepath = $this->temp_dir . $file;
518
519        $path = $this->makeThumb($filepath, $to_w, $to_h);
520
521        // ファイル名だけ返す
522        return basename($path);
523    }
524
525    /**
526     * 一時保存用のファイル名を生成する
527     *
528     * @param  string $rename
529     * @param  int    $keyname
530     * @return string
531     */
532    public function lfGetTmpImageName($rename, $keyname = '', $uploadfile = '')
533    {
534        if ($rename === true) {
535            // 一意なIDを取得し、画像名をリネームし保存
536            $uniqname = date('mdHi') . '_' . uniqid('');
537        } else {
538            // アップロードした画像名で保存
539            $uploadfile = strlen($uploadfile) > 0 ? $uploadfile : $_FILES[$keyname]['name'];
540            $uniqname =  preg_replace('/(.+)\.(.+?)$/','$1', $uploadfile);
541        }
542        $dst_file = $this->temp_dir . $uniqname;
543
544        return $dst_file;
545    }
546}
Note: See TracBrowser for help on using the repository browser.