-
- //-------------------------- -----------
- // 파일 설명: 파일 업로드 처리 클래스
- // 파일 작성자: Jesse Lee
- // 작성자 홈페이지: http://bbs.it-home .org
- // 최종 업데이트 날짜: 2011-5-14
- //------------------ --- -------
- 클래스 업로드 {
- var $dir; //첨부파일이 저장되는 물리적 디렉터리
- var $time; //파일 업로드 시간 맞춤
- var $allow_types ; //업로드 첨부 유형 허용
- var $field; //업로드 제어 이름
- var $maxsize; //최대 허용 파일 크기, 단위는 KB
- //썸네일 너비
- var $thumb_height ; //썸네일 높이
- var $watermark_file; //워터마크 이미지 주소
- var $watermark_pos; //워터마크 위치
- var $watermark_trans;//워터마크 투명도
- //생성자 > //$types: 업로드가 허용되는 파일 형식, $maxsize: 허용 크기, $field: 업로드 제어 이름, $time: 사용자 지정 업로드 시간
- function upload($types = 'jpg|png', $maxsize = 1024 , $field = '첨부', $time = '') {
- $this->allow_types =explore('|',$types);
- $this->maxsize = $maxsize * 1024 ;
- $this->field = $field;
- $this->time = $time ? $time : time();
- }
- //특정 디렉터리를 설정하고 생성합니다. 파일이 저장됩니다
- //$basedir: 기본 디렉터리, 실제 경로여야 합니다
- //$filedir: 사용자 정의 하위 디렉터리, 사용 가능한 매개변수 {y}, {m}, {d}
- function set_dir( $basedir, $filedir = '') {
- $dir = $basedir;
- !is_dir($dir) && @mkdir($dir,0777);
- if (!empty($filedir)) {
- $filedir = str_replace(array('{y}','{m}','{y}'),array(date('Y',$this->time),date('m ',$ this->time),date('d',$this->time)),strtolower($filedir));
- $dirs =Explode('/',$filedir);
- foreach ( $dirs as $d) {
- !empty($d) && $dir .= $d.'/';
- !is_dir($dir) && @mkdir($dir,0777);
- }
- }
- $this->dir = $dir;
- }
- //사진 썸네일 설정, 썸네일이 생성되지 않으면 설정할 필요가 없습니다
- //$width : 썸네일 너비, $height: 썸네일 높이
- function set_thumb ($width = 0, $height = 0) {
- $this->thumb_width = $width;
- $this->thumb_height = $ height ;
- }
- //그림 워터마크 설정, 워터마크가 생성되지 않으면 설정 필요 없음
- //$file: 워터마크 이미지, $pos: 워터마크 위치, $trans: 워터마크 투명도
- 기능 set_watermark ( $file, $pos = 6, $trans = 80) {
- $this->watermark_file = $file;
- $this->watermark_pos = $pos;
- $this-> watermark_trans = $trans;
- }
- /*-------------------------------------- ----- -------------
- 파일 업로드를 실행하고 업로드 성공 또는 실패가 포함된 파일 정보 배열을 반환합니다. 처리 후
- 그 중 name은 파일 이름입니다. 업로드가 성공하면 서버에 업로드된 파일 이름입니다. 업로드에 실패하면 로컬 파일 이름이 됩니다.
- dir은 실제 경로입니다. 첨부 파일이 서버에 저장되는 경우, 이 값은 존재하지 않습니다.
- size는 업로드가 실패한 경우의 값입니다.
- 플래그는 상태 표시기입니다. 성공을 의미하고 -1은 파일 형식이 허용되지 않음을 의미하며 -2는 파일 크기가
- 을 초과함을 의미합니다. ---------- ----------------- --------------------------------- ----- */
- 함수 실행() {
- $files = array(); //파일 정보 업로드 성공
- $field = $this->field;
- $keys = array_keys($_FILES[$field]['name']);
- foreach ($keys as $key) {
- if (!$_FILES[$field]['name'][$key]) continue;
-
- $fileext = $this->fileext( $_FILES[$field]['name'][$key]); //파일 확장자 가져오기
- $filename = $this- >time.mt_rand(100,999).'.'.$fileext; 생성된 파일명
- $filedir = $this->dir; //첨부파일이 저장된 실제 디렉터리
- $filesize = $_FILES[$ field]['size'][$key]; size
-
- //허용되지 않는 파일 형식
- if (!in_array($fileext,$this->allow_types)) {
- $files[$key]['name'] = $_FILES [$field]['name'][$key];
- $files[$key]['flag'] = -1;
- continue;
- }
- //파일 크기 초과
- if ($filesize > $this->maxsize) {
- $files[$key]['name'] = $_FILES[$ field]['name'][$key];
- $files[$key]['flag'] = -2;
- 계속;
- }
- $files[$key]['name'] = $filename;
- $files[$key]['dir'] = $filedir;
- $files[$key]['size'] = $filesize;
- //업로드한 파일을 저장하고 임시 파일을 삭제합니다
- if (is_uploaded_file($_FILES[$field]['tmp_name'][$key])) {
- move_uploaded_file($_FILES [$ 필드]['tmp_name'][$key],$filedir.$filename);
- @unlink($_FILES[$field]['tmp_name'][$key]);
- $files[ $key ]['flag'] = 1;
- //이미지 워터마크 및 썸네일 생성
- if (in_array($fileext,array('jpg','png','gif'))) {
- if ($this->thumb_width) {
- if ($this->create_thumb($filedir.$filename,$filedir.'thumb_'.$filename)) {
- $files[$ key] ['thumb'] = 'thumb_'.$filename; //썸네일 파일 이름
- }
- }
- $this->create_watermark($filedir.$filename);
- }
- }
- }
- return $files;
- }
- //썸네일 생성, 동일한 확장자를 가진 썸네일 생성
- //Php.aspx_file: 소스 이미지 경로, $ Thumb_file : 썸네일 경로
- function create_thumb (Php.aspx_file,$thumb_file) {
- $t_width = $this->thumb_width;
- $t_height = $this->thumb_height;
- if ( !file_exists(Php.aspx_file) ) return false;
- Php.aspx_info = getImageSize(Php.aspx_file);
- //소스 이미지가 썸네일보다 작거나 같으면 소스 이미지를 썸네일로 복사
- if ( Php. aspx_info[0] <= $t_width && Php.aspx_info[1] <= $t_height) {
- if (!copy(Php.aspx_file,$thumb_file)) {
- return false;
- }
- return true;
- }
- //썸네일 크기를 비례적으로 계산
- if (Php.aspx_info[0] - $t_width > Php.aspx_info[1] - $t_height) {
- $ t_height = ($t_width / Php.aspx_info[0]) * Php.aspx_info[1];
- } else {
- $t_width = ($t_height / Php.aspx_info[1]) * Php .aspx_info[0 ];
- }
- //파일 확장자 가져오기
- $fileext = $this->fileext(Php.aspx_file);
- 스위치($fileext) {
- 케이스 'jpg' :
- Php.aspx_img = ImageCreateFromJPEG(Php.aspx_file); break;
- 케이스 'png' :
- Php.aspx_img = ImageCreateFromPNG(Php.aspx_file) break;
- 케이스 'gif' :
- Php.aspx_img = ImageCreateFromGIF(Php.aspx_file); break;
- }
- //트루 컬러 썸네일 이미지 생성
- $thumb_img = @ImageCreateTrueColor($t_width,$t_height) ;
- //The ImageCopyResampled 함수로 복사한 이미지의 부드러움이 더 좋으며 우선순위가 부여됩니다
- if (function_exists('imagecopyresampled')) {
- @ImageCopyResampled($thumb_img,Php.aspx_img,0,0,0, 0,$t_width, $t_height,Php.aspx_info[0],Php.aspx_info[1]);
- } else {
- @ImageCopyReised($thumb_img,Php.aspx_img,0,0,0,0, $t_width,$t_height ,Php.aspx_info[0],Php.aspx_info[1]);
- }
- //썸네일 생성
- switch ($fileext) {
- case 'jpg' :
- ImageJPEG($ Thumb_img,$thumb_file); break;
- case 'gif' :
- ImageGIF($thumb_img,$thumb_file); break;
- case 'png' :
- ImagePNG($ Thumb_img,$thumb_file); break;
- }
- //임시 이미지 삭제
- @ImageDestroy(Php.aspx_img);
- @ImageDestroy($thumb_img);
- return true;
- }
- //사진에 워터마크 추가
- //$file: 워터마크할 파일
- function create_watermark($file) {
- //파일이 없으면
- 을 반환합니다. (!file_exists( $this->watermark_file) || !file_exists($file)) return;
- if (!function_exists('getImageSize')) return;
-
- //지원되는 파일 형식 확인 by GD
- $gd_allow_types = array();
- if (function_exists('ImageCreateFromGIF')) $gd_allow_types['image/gif'] = 'ImageCreateFromGIF';
- if (function_exists('ImageCreateFromPNG')) $gd_allow_types['image /png'] = 'ImageCreateFromPNG';
- if (function_exists('ImageCreateFromJPEG')) $gd_allow_types['image/jpeg'] = 'ImageCreateFromJPEG';
- //파일 정보 가져오기
- $fileinfo = getImageSize ($file);
- $wminfo = getImageSize($this->watermark_file);
- if ($fileinfo[0] < $wminfo[0] || $fileinfo[1] < $wminfo[ 1]) 반환;
- if (array_key_exists($fileinfo['mime'],$gd_allow_types)) {
- if (array_key_exists($wminfo['mime'],$gd_allow_types)) {
-
- //파일에서 이미지 생성
- $temp = $gd_allow_types[$fileinfo['mime']]($file);
- $temp_wm = $gd_allow_types[$wminfo['mime'] ]($this- >watermark_file);
- //워터마크 위치
- 스위치 ($this->watermark_pos) {
- 사례 1 : //왼쪽 상단
- $dst_x = 0; = 0; 중단;
- 사례 2: //상단 중앙
- $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = 0; //오른쪽 위
- $dst_x = $fileinfo[0]; $dst_y = 0; break;
- 사례 4: //왼쪽 아래
- $dst_y = $fileinfo[1]; break;
- 사례 5: //하단이 중앙에 위치함
- $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = $fileinfo[1] break;
- 사례 6: //오른쪽 하단
- $dst_x = $fileinfo[0]-$wminfo[0] $dst_y = $fileinfo[1]-$wminfo[1] break;
- 기본값: // 무작위
- $dst_x = mt_rand(0,$fileinfo[0]-$wminfo[0]) $dst_y = mt_rand(0,$fileinfo[1]-$wminfo[1]);
- }
- if (function_exists(' ImageAlphaBlending')) ImageAlphaBlending($temp_wm,True); //이미지 블렌딩 모드 설정
- if (function_exists('ImageSaveAlpha')) ImageSaveAlpha($temp_wm,True); 알파 채널 정보
- //이미지에 워터마크 추가
- if (function_exists('imageCopyMerge')) {
- ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[ 0],$wminfo[ 1],$this->watermark_trans);
- } else {
- ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0], $wminfo[1]) ;
- }
- //이미지 저장
- switch ($fileinfo['mime']) {
- case 'image/jpeg' :
- @imageJPEG($ temp,$file);
- break;
- case 'image/png' :
- @imagePNG($temp,$file);
- break;
- case 'image/gif' :
- @imageGIF($temp ,$file);
- break;
- }
- //제로타임 이미지 삭제
- @imageDestroy($temp);
- @imageDestroy($temp_wm );
- }
- }
- }
- //파일 확장자 가져오기
- function fileext($filename) {
- return strtolower(substr(strrchr($filename,'.')), 1,10));
- }
- }
- ?>
-
코드 복사 사용 예:
|