>  기사  >  백엔드 개발  >  PHP 파일 업로드 클래스 공유

PHP 파일 업로드 클래스 공유

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

사용 예:

  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으로 문의하세요.