{Y}{m}{n}을 사용하여 현재 날짜를 변경할 수 있습니다
- set_dir(dirname(__FILE__).'/upload/','{y}/{m} '); //경로 저장, {y}{m}{d} 옵션 지원
- $up->set_thumb(100,80); //썸네일 크기 설정은 픽셀
- $up- >set_watermark(dirname(__FILE__).'/jblog/images/watermark.png',6,90); //워터마크 설정
- $fs = $up->execute() //실행 시작
-
- var_dump($fs); //테스트용 클래스 보기
- }
- ?>
- /////양식 보기---------
-
- test
-
- //다중 이미지 업로드 지원
-
-
-
-
-
- */
- class upload {
-
- var $dir; //첨부파일이 저장되는 물리적 디렉토리
- var $time; //파일 업로드 시간 맞춤
- var $allow_types; //첨부파일 유형 업로드 허용
- var $field; > var $maxsize; //최대 허용 파일 크기(KB)
-
- var $thumb_width; //썸네일 너비
- var $thumb_height; //썸네일 높이
-
- // 워터마크 이미지 주소
- var $watermark_pos; //워터마크 위치
- var $watermark_trans;//워터마크 투명도
-
- //Constructor
- //$types: 업로드할 수 있는 파일 형식, $ maxsize: 허용된 크기, $field: 업로드 제어 이름, $time: 사용자 정의 업로드 시간
- function upload($types = 'jpg|png', $maxsize = 1024, $field = 'attach', $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}','{d}'),array(date('Y',$this->time),date('m',$this- >time),date ('d',$this->time)),strtolower($filedir));//string_replace를 사용하여 {y} {m} {d} 태그 교체
- $ dirs =explore('/',$ 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: 워터마크 position, $trans: 워터마크 투명도
- function set_watermark ($file, $pos = 6, $trans = 80) {
- $this->watermark_file = $file
- $this->watermark_pos = $pos
- $this->watermark_trans = $trans
- }
-
- /*————————————————————————-
- 파일 업로드를 실행하고 업로드 성공이 포함된 파일 정보 배열을 반환합니다. 처리 후 실패.
- 그 중 name은 파일 이름입니다. 업로드에 실패한 경우에는 로컬 파일 이름입니다. 업로드가 실패하면 첨부 파일이 존재하지 않는 실제 경로입니다.
- 크기는 업로드에 실패하면
- 플래그가 존재하지 않는 것입니다. 1은 성공을 나타내고, -1은 파일 형식이 허용되지 않음을 나타내며, -2는 파일 크기가
- 을 초과함을 나타냅니다. —————— —————————————— ——–*/
- function excute() {
- $files = array(); //파일 정보 업로드 성공
- $field = $ this->field
- $keys = array_keys( $_FILES[$field]['name']);
- foreach ($keys as $key) {
- if (!$_FILES[$field ]['name'][$key]) 계속; 🎜>
- $fileext = $this->fileext($_FILES[$field]['name'][$key]); //파일 확장자 가져오기
- $filename = date('Ymdhis', $this->time).mt_rand(10,99).'.'.$fileext; //파일명 생성
- $filedir = $this- >dir; //첨부파일이 저장된 실제 디렉터리
- $filesize = $_FILES[$field]['size'][$key]; //파일 크기
-
- //파일 형식이 허용되지 않습니다
- if (!in_array($fileext,$this ->allow_types)) {
- $files[$key]['name'] = $_FILES[$field]['name'][$key]; $files[$key]['flag '] = -1;
- 계속;
- }
-
- //파일 크기 초과
- if ($filesize > $this-> ;maxsize) {
- $files[$ 키]['이름'] = $_FILES[$필드]['이름'][$key]
- $files[$key]['name'] = $filesize; ]['flag'] = -2;
- 계속;
- }
-
- $files[$key]['name'] = $filename ; 'dir'] = $filedir;
- $files[$key]['size'] = $filesize;
-
- //업로드한 파일을 저장하고 임시 파일을 삭제합니다.
- if (is_uploaded_file( $_FILES[$field]['tmp_name'][$key])) {
- move_uploaded_file($_FILES[$field]['tmp_name'][$key],$filedir .$filename)
- @ unlink($_FILES[$field]['tmp_name'][$key]);
- $files[$key]['flag'] = 1;
-
- //사진에 워터마크를 추가하고 여기의 데모는 jpg 및 png만 지원합니다(gif가 생성되면 프레임이 손실됩니다)
- if (in_array($fileext,array('jpg','png') )) {
- if ($this->thumb_width) {
- if ($this->create_thumb($filedir.$filename,$filedir.'thumb_'.$filename)) {
- $ 파일[$key][ 'thumb'] = 'thumb_'.$filename; //썸네일 파일 이름
- }
- }
- $this->create_watermark($filedir.$filename);
- }
-
- return $files;
- }
-
- //썸네일 생성, 동일한 확장자를 사용하여 썸네일 생성
- // $src_file: 소스 이미지 경로, $thumb_file: 썸네일 경로
- function create_thumb ($src_file,$thumb_file) {
- $t_width = $this->thumb_width;
- $t_height = $this-> Thumb_height; file_exists($src_file)) return false
-
- $src_info = getImageSize($src_file);
-
- //소스 이미지가 썸네일보다 작거나 같은 경우 소스 이미지를 다음과 같이 복사합니다. 작업이 필요 없는 썸네일
- if ($src_info[0] <= $t_width && $src_info[1] <= $t_height) {
- if (!copy($src_file ,$thumb_file) ) {
- return false
- }
- return true
- }
- //썸네일 크기를 비례적으로 계산
- if (($src_info[0 ]-$t_width) > ; ($src_info[1]-$t_height)) {
- $t_height = ($t_width / $src_info[0]) * $src_info[1]
- } else {
- $t_width = ($ t_height / $src_info[1]) * $src_info[0]
- }
- //파일 확장자 가져오기
- $fileext = $this->fileext($src_file)
-
- switch ($fileext) {
- case 'jpg' :
- $src_img = ImageCreateFromJPEG($src_file);
- 케이스 'png' :
- $src_img = ImageCreateFromPNG($src_file)
- 케이스 'gif' :
- $src_img = ImageCreateFromGIF ($src_file); break;
-
- //트루 컬러 썸네일 이미지 생성
- $thumb_img = @ImageCreateTrueColor($t_width,$t_height) / 이미지 /ImageCopyResampled 함수로 복사하면 부드러움이 더 좋고 우선순위가 부여됩니다.
- if (function_exists('imagecopyresampled')) {
- @ImageCopyResampled($thumb_img,$src_img,0,0,0,0,$t_width,$ t_height,$src_info[0],$src_info[1]);
- } else {
- @ImageCopyReized($thumb_img,$src_img,0,0,0,0,$t_width,$t_height,$src_info[ 0],$src_info[1])
- }
-
- //썸네일 생성
- switch ($fileext) {
- case 'jpg' :
- ImageJPEG($thumb_img, $ Thumb_file);
- Case 'gif' :
- ImageGIF($thumb_img,$thumb_file); break;
- ImagePNG($thumb_img,$thumb_file); 🎜> }
-
- //임시 이미지 삭제
- @ImageDestroy($src_img);
- @ImageDestroy($thumb_img)
-
- return true;
-
- //사진에 워터마크 추가
- //$file : 워터마크를 추가할 파일
- function create_watermark ($file) {
-
- //파일이 없으면 반환
- if (!file_exists($this->watermark_file) || !file_exists($file)) return
- if (!function_exists('getImageSize')) return
-
- //확인 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]) return
- 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; $dst_y = 0; break;
- 사례 2 : //상단 중앙
- $dst_x = ($fileinfo[0] - $wminfo[0])/2 ; $dst_y = 0;
- 케이스 3 : //오른쪽 위
- $dst_x = $dst_y = 0;
- 케이스 4 : //왼쪽
- $dst_x = 0; $dst_y = $fileinfo[1];
- 사례 5 : // 하단 중앙
- $dst_x = ($fileinfo[0] - $wminfo[0]) / 2; = $fileinfo[1]; 중단;
- 사례 6: //오른쪽 하단
- $dst_x = $fileinfo[0]-$wminfo[0]; ]; 중단;
- 기본값 : //Random
- $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])
- }
-
- //저장 image
- 스위치($fileinfo['mime']) {
- 케이스 'image/jpeg' :
- @imageJPEG($temp,$file)
- break
- 케이스 'image/ png ' :
- @imagePNG($temp,$file);
- break
- case 'image/gif' :
- @imageGIF($temp,$file); 🎜 > }
- //제로타임 이미지 삭제
- @imageDestroy($temp)
- @imageDestroy($temp_wm)
- }
- }
- }
-
- / /파일 확장자 가져오기
- function fileext($filename) {
- return strtolower(substr(strrchr($filename,'.'),1,10))
- }
- }
- ?>
-
-
코드 복사
|
이미지 업로드, PHP