>백엔드 개발 >PHP 튜토리얼 >유용한 PHP 파일 업로드 처리 클래스

유용한 PHP 파일 업로드 처리 클래스

WBOY
WBOY원래의
2016-07-25 09:08:09804검색
  1. //-------------------------- -----------
  2. // 파일 설명: 파일 업로드 처리 클래스
  3. // 파일 작성자: Jesse Lee
  4. //------------ --------------------------
  5. 클래스 업로드 {
  6. var $dir; //첨부 파일이 저장되는 물리적 디렉터리
  7. var $time ; //사용자 지정 파일 업로드 시간
  8. var $allow_types; //업로드 첨부 파일 유형 허용
  9. var $field; //업로드 제어 이름
  10. var $maxsize; 단위는 KB입니다.
  11. var $thumb_width; //썸네일 너비
  12. var $thumb_height; //썸네일 높이
  13. var $watermark_file; //워터마크 이미지 주소
  14. //워터마크 위치
  15. var $watermark_trans;//워터마크 투명성
  16. //생성자
  17. //$types: 업로드가 허용되는 파일 형식, $maxsize: 허용 크기, $field: 업로드 제어 이름, $time: 사용자 지정 업로드 시간
  18. 함수 업로드($types = 'jpg|png', $maxsize = 1024, $field = 'attach', $time = '') {
  19. $this->allow_types =explore('|',$ 유형);
  20. $this->maxsize = $maxsize * 1024;
  21. $this->field = $field;
  22. $this->time = $time : time() ;
  23. }
  24. //파일이 구체적으로 저장되는 디렉터리 설정 및 생성
  25. //$basedir: 기본 디렉터리, 실제 경로여야 함
  26. //$filedir: 사용자 정의 하위 디렉터리, 사용 가능한 매개변수 { y }, {m}, {d}
  27. function set_dir($basedir,$filedir = '') {
  28. $dir = $basedir;
  29. !is_dir($dir) && @mkdir($dir , 0777);
  30. if (!empty($filedir)) {
  31. $filedir = str_replace(array('{y}','{m}','{y}'),array(date( ' Y',$this->time),date('m',$this->time),date('d',$this->time)),strtolower($filedir));
  32. $dirs = 폭발('/',$filedir);
  33. foreach ($dirs를 $d로) {
  34. !empty($d) && $dir .= $d.'/';
  35. ! is_dir($dir) && @mkdir($dir,0777);
  36. }
  37. }
  38. $this->dir = $dir;
  39. }
  40. //사진 썸네일 설정, 썸네일이 생성되지 않으면 설정할 필요가 없습니다.
  41. //$width: 썸네일 너비, $height: 썸네일 높이
  42. function set_thumb ($width = 0, $height = 0) {
  43. $this -> ;thumb_width = $width;
  44. $this->thumb_height = $height;
  45. }
  46. //그림 워터마크 설정, 워터마크가 생성되지 않으면 설정 필요 없음
  47. //$file : 워터마크 사진 , $pos: 워터마크 위치, $trans: 워터마크 투명도
  48. function set_watermark ($file, $pos = 6, $trans = 80) {
  49. $this->watermark_file = $file;
  50. $this ->watermark_pos = $pos;
  51. $this->watermark_trans = $trans;
  52. }
  53. /*----------------- --------- --------------- ---------
  54. 파일 업로드 실행, 처리 후 업로드 성공 또는 실패를 포함하는 파일 정보 배열이 반환됩니다.
  55. 여기서: name은 파일 이름이며, 업로드가 성공하면 는 서버에 업로드된 파일 이름이며, 업로드 실패 시 로컬 파일 이름입니다.
  56. dir은 서버에 첨부 파일이 저장된 실제 경로입니다.
  57. size는 업로드가 실패한 경우 이 값이 존재하지 않습니다.
  58. 플래그는 상태 식별자이며, 1은 성공을 의미하고, -1은 파일 형식이 허용되지 않음을 의미하며, - 2는 파일 크기가 ------------------- ---- ------ */
  59. function excute() {
  60. $files = array() //파일 정보 업로드 성공
  61. $field = $this->field;
  62. $keys = array_keys($_FILES[$field]['name']);
  63. foreach ($keys를 $key로) {
  64. if (!$_FILES[ $field]['name'][$key]) 계속;
  65. $fileext = $this->fileext($_FILES[$field]['name'][$key ]) // 파일 확장자 가져오기
  66. $filename = $this->time.mt_rand(100,999).'.'.$fileext; //파일 이름 생성
  67. $filedir = $this-> 첨부 파일 저장 디렉터리
  68. $filesize = $_FILES[$field]['size'][$key] //파일 크기
  69. //파일 형식이 허용되지 않음
  70. if (!in_array( $fileext,$this->allow_types)) {
  71. $files[$key]['name'] = $_FILES[$field]['name'][$key];
  72. $files[$ key]['flag'] = -1;
  73. continue;
  74. }
  75. //파일 크기가 초과됩니다
  76. if ($filesize > $this->maxsize) {
  77. $files [$key]['name'] = $_FILES[$field]['name'][$key];
  78. $files[$key]['flag'] = -2;
  79. 계속;
  80. }
  81. $files[$key]['name'] = $filename;
  82. $files[$key]['dir'] = $filedir;
  83. $files[$key]['size'] = $filesize;
  84. //업로드한 파일을 저장하고 임시 파일을 삭제합니다
  85. if (is_uploaded_file($_FILES[$field]['tmp_name'][$key])) {
  86. move_uploaded_file($_FILES [$ 필드]['tmp_name'][$key],$filedir.$filename);
  87. @unlink($_FILES[$field]['tmp_name'][$key]);
  88. $files[ $key ]['flag'] = 1;
  89. //이미지 워터마크 및 썸네일 생성
  90. if (in_array($fileext,array('jpg','png','gif'))) {
  91. if ($this->thumb_width) {
  92. if ($this->create_thumb($filedir.$filename,$filedir.'thumb_'.$filename)) {
  93. $files[$ key] ['thumb'] = 'thumb_'.$filename; //썸네일 파일 이름
  94. }
  95. }
  96. $this->create_watermark($filedir.$filename);
  97. }
  98. }
  99. }
  100. return $files;
  101. }
  102. //썸네일 생성, 동일한 확장자를 가진 썸네일 생성
  103. //Php.aspx_file: 소스 이미지 경로, $ Thumb_file : 썸네일 경로
  104. function create_thumb (Php.aspx_file,$thumb_file) {
  105. $t_width = $this->thumb_width;
  106. $t_height = $this->thumb_height;
  107. if ( !file_exists(Php.aspx_file) ) return false;
  108. Php.aspx_info = getImageSize(Php.aspx_file);
  109. //소스 이미지가 썸네일보다 작거나 같으면 소스 이미지를 썸네일로 복사
  110. if ( Php. aspx_info[0] <= $t_width && Php.aspx_info[1] <= $t_height) {
  111. if (!copy(Php.aspx_file,$thumb_file)) {
  112. return false;
  113. }
  114. return true;
  115. }
  116. //썸네일 크기를 비례적으로 계산
  117. if (Php.aspx_info[0] - $t_width > Php.aspx_info[1] - $t_height) {
  118. $ t_height = ($t_width / Php.aspx_info[0]) * Php.aspx_info[1];
  119. } else {
  120. $t_width = ($t_height / Php.aspx_info[1]) * Php .aspx_info[0 ];
  121. }
  122. //파일 확장자 가져오기
  123. $fileext = $this->fileext(Php.aspx_file);
  124. 스위치($fileext) {
  125. 케이스 'jpg' :
  126. Php.aspx_img = ImageCreateFromJPEG(Php.aspx_file); break;
  127. 케이스 'png' :
  128. Php.aspx_img = ImageCreateFromPNG(Php.aspx_file) break;
  129. 케이스 'gif' :
  130. Php.aspx_img = ImageCreateFromGIF(Php.aspx_file); break;
  131. }
  132. //트루 컬러 썸네일 이미지 생성
  133. $thumb_img = @ImageCreateTrueColor($t_width,$t_height) ;
  134. //The ImageCopyResampled 함수로 복사한 이미지의 부드러움이 더 좋으며 우선순위가 부여됩니다
  135. if (function_exists('imagecopyresampled')) {
  136. @ImageCopyResampled($thumb_img,Php.aspx_img,0,0,0, 0,$t_width, $t_height,Php.aspx_info[0],Php.aspx_info[1]);
  137. } else {
  138. @ImageCopyReised($thumb_img,Php.aspx_img,0,0,0,0, $t_width,$t_height ,Php.aspx_info[0],Php.aspx_info[1]);
  139. }
  140. //썸네일 생성
  141. switch ($fileext) {
  142. case 'jpg' :
  143. ImageJPEG($ Thumb_img,$thumb_file); break;
  144. case 'gif' :
  145. ImageGIF($thumb_img,$thumb_file); break;
  146. case 'png' :
  147. ImagePNG($ Thumb_img,$thumb_file); break;
  148. }
  149. //임시 이미지 삭제
  150. @ImageDestroy(Php.aspx_img);
  151. @ImageDestroy($thumb_img);
  152. return true;
  153. }
  154. //사진에 워터마크 추가
  155. //$file: 워터마크할 파일
  156. function create_watermark($file) {
  157. //파일이 없으면
  158. 을 반환합니다. (!file_exists( $this->watermark_file) || !file_exists($file)) return;
  159. if (!function_exists('getImageSize')) return;
  160. //지원되는 파일 형식 확인 by GD
  161. $gd_allow_types = array();
  162. if (function_exists('ImageCreateFromGIF')) $gd_allow_types['image/gif'] = 'ImageCreateFromGIF';
  163. if (function_exists('ImageCreateFromPNG')) $gd_allow_types['image /png'] = 'ImageCreateFromPNG';
  164. if (function_exists('ImageCreateFromJPEG')) $gd_allow_types['image/jpeg'] = 'ImageCreateFromJPEG';
  165. //파일 정보 가져오기
  166. $fileinfo = getImageSize ($file);
  167. $wminfo = getImageSize($this->watermark_file);
  168. if ($fileinfo[0] < $wminfo[0] || $fileinfo[1] < $wminfo[ 1]) 반환;
  169. if (array_key_exists($fileinfo['mime'],$gd_allow_types)) {
  170. if (array_key_exists($wminfo['mime'],$gd_allow_types)) {
  171. //파일에서 이미지 생성
  172. $temp = $gd_allow_types[$fileinfo['mime']]($file);
  173. $temp_wm = $gd_allow_types[$wminfo['mime'] ]($this- >watermark_file);
  174. //워터마크 위치
  175. 스위치 ($this->watermark_pos) {
  176. 사례 1 : //왼쪽 상단
  177. $dst_x = 0; = 0; 중단;
  178. 사례 2: //상단 중앙
  179. $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = 0; //오른쪽 위
  180. $dst_x = $fileinfo[0]; $dst_y = 0; break;
  181. 사례 4: //왼쪽 아래
  182. $dst_y = $fileinfo[1]; break;
  183. 사례 5: //하단이 중앙에 위치함
  184. $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; $dst_y = $fileinfo[1] break;
  185. 사례 6: //오른쪽 하단
  186. $dst_x = $fileinfo[0]-$wminfo[0] $dst_y = $fileinfo[1]-$wminfo[1] break;
  187. 기본값: // 무작위
  188. $dst_x = mt_rand(0,$fileinfo[0]-$wminfo[0]) $dst_y = mt_rand(0,$fileinfo[1]-$wminfo[1]);
  189. }
  190. if (function_exists(' ImageAlphaBlending')) ImageAlphaBlending($temp_wm,True); //이미지 블렌딩 모드 설정
  191. if (function_exists('ImageSaveAlpha')) ImageSaveAlpha($temp_wm,True); 알파 채널 정보
  192. //이미지에 워터마크 추가
  193. if (function_exists('imageCopyMerge')) {
  194. ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[ 0],$wminfo[ 1],$this->watermark_trans);
  195. } else {
  196. ImageCopyMerge($temp,$temp_wm,$dst_x,$dst_y,0,0,$wminfo[0], $wminfo[1]) ;
  197. }
  198. //이미지 저장
  199. switch ($fileinfo['mime']) {
  200. case 'image/jpeg' :
  201. @imageJPEG($ temp,$file);
  202. break;
  203. case 'image/png' :
  204. @imagePNG($temp,$file);
  205. break;
  206. case 'image/gif' :
  207. @imageGIF($temp ,$file);
  208. break;
  209. }
  210. //제로타임 이미지 삭제
  211. @imageDestroy($temp);
  212. @imageDestroy($temp_wm );
  213. }
  214. }
  215. }
  216. //파일 확장자 가져오기
  217. function fileext($filename) {
  218. return strtolower(substr(strrchr($filename,'.')), 1,10));
  219. }
  220. }
  221. ?>
코드 복사

사용 예:

  1. if ($_GET['action'] == 'save') {
  2. $up = new upload();
  3. $up->set_dir(dirname(__FILE__).'/upload/','{y}/{m}');
  4. $up->set_thumb(100,80 );
  5. $up->set_watermark(dirname(__FILE__).'/jblog/images/watermark.png',6,90);
  6. $fs = $up->execute();
  7. var_dump($fs);
  8. }
  9. ?>
  10. test
제제대码


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.