메뉴 건너뛰기

프로그램언어

조회 수 28547 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

PHP를 이용한 간단한 파일 업로드, 다운로드를 가능하게 하는 소스다. 요즘은 함수나 클래스로 구현하는 경우가 많지만, 간단하게 사용할 수 있도록 별다른 기능을 넣지는 않았다.

이 소스를 기본으로 다중파일 업로드와 업로드 된 파일을 다운로드 받을 시, 파일 확장자를 체크하여 이미지 파일이면 다운로드 받지 않고 브라우저에서 직접 보이도록 하는 기능은 직접 구현하기 바란다.

Up_Load_Form.html (파일 업로드 화면)

<form name="form1" method="post" enctype="multipart/form-data" action="File_Upload.php">
<table width="600" border="0" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC">
<tr>
   <td colspan="2" bgcolor="#FFFFFF">PHP를 이용한 파일업로드 기능의 구현</td>
</tr>
<tr>
   <td width="150" align="center" bgcolor="#FFFFFF">업로드할 파일</td>
   <td width="464" bgcolor="#FFFFFF"><input type="file" name="myFile" size="60" /></td>
</tr>
<tr>
   <td colspan="2" bgcolor="#FFFFFF"><input type="submit" value="파일 업로드" />
   <input type="reset" value="취소" /></td>
</tr>
</table>
</form>

File_Upload.php (파일 업로드)

<? 
//업로드한 파일을 저장할 디렉토리 
$save_dir = "files/"; 
  
//파일이 HTTP POST 방식을 통해 정상적으로 업로드되었는지 확인한다. 
if(is_uploaded_file($_FILES["myFile"]["tmp_name"])) 
{ 
   echo "업로드한 파일명 : ".$_FILES["myFile"]["name"] ."<br />"; 
   echo "업로드한 파일의 크기 : ".$_FILES["myFile"]["size"] ."<br />"; 
   echo "업로드한 파일의 MIME Type : ".$_FILES["myFile"]["type"] ."<br />"; 
   echo "임시 디렉토리에 저장된 파일명 : ".$_FILES["myFile"]["tmp_name"]."<br />"; 
  
   //파일을 저장할 디렉토리 및 파일명 
   $dest = $save_dir . $_FILES["myFile"]["name"]; 
  
   //파일을 지정한 디렉토리에 저장 
   if(!move_uploaded_file($_FILES["myFile"]["tmp_name"], $dest)) 
   { 
      die("파일을 지정한 디렉토리에 저장하는데 실패했습니다."); 
   } 
} 
?> 

필자의 경우 파일 중복을 피하기 위해서
$fn = $_FILES["myFile"]["name"];
$fn = mktime()."^".$fn;
DB 삽입시 파일명을 (시간 + ^+ 파일명) 형태로 가공해서 넣었다. 나중에 다운로드를 구현할 때 "^" 기준으로 잘라내면 뒷부분이 원본 파일 이름이 된다.

다운로드 링크

<a href="down('파일명')">다운로드</a>
<script>
function dwon(fileName)
{
   url = "Down_Load.php"+fileName;
   location.href = url;
}
</script>


Down_Load.php (다운로드 받는 페이지 구현)

<? 
$fileName = $_REQUEST[fileName]; 
$DownloadPath = "./files/".$fileName; // 파일 경로 
$fileTmp = strstr($fileName, '^'); // 파일명 임시저장(앞의 '^'를 제거 
$DownFile = substr($fileTmp, 2); 
  
Header("Content-Type: file/unknown"); 
Header("Content-Disposition: attachment; filename=". $DownFile; 
Header("Content-Length: ".filesize("$DownloadPath")); 
header("Content-Transfer-Encoding: binary "); 
Header("Pragma: no-cache"); 
Header("Expires: 0"); 
flush(); 
  
if ($fp = fopen("$downloadPath", "r")) 
{ 
   print fread($fp, filesize("$DownloadPath")); 
} 
fclose($fp); 
?>




List of Articles
번호 제목 날짜 조회 수
280 MYSQL DB 다중접속을 해결 하는 한 방법 2021.03.26 284
279 MySQL DB 중복여부 검사하여 없는 것만 추가 2015.04.14 20157
278 MYSQL DB의 모든 테이블에서 문자열 검색 하기 2021.03.26 915
277 MYSQL 업데이트 두 번 하기 2014.02.27 19729
276 mysql 에러 구문 표시 2014.02.27 20349
275 MySQL(MariaDB) 테이블 만들기 2018.03.28 8154
274 mysql_affected_rows — 최근 MySQL 작업으로 변경된 행 개수를 얻음 2016.12.23 18807
273 mysql_free_result(); 관련 오류 2021.03.25 314
272 mysql_insert_id 2016.12.23 18750
271 mysql_real_escape_string 이진 데이터를 입력할 경우 이 함수를 사용해야 함 2016.12.23 18640
270 mysql_result — 결과 데이터를 반환 2016.12.23 18967
269 MySQL테이블의 내용을 엑셀파일(xls)로 다운로드 하기 2018.07.24 4798
268 parse_ini_file — Parse a configuration file 2016.12.23 19774
267 PEAR DB 관련 함수들 2021.03.26 690
266 PHP $_SERVER 함수 2019.02.25 1558
265 PHP + 유튜브(youtube) 동영상 업로드 연동 소스 2021.01.21 1141
264 PHP - 공공 DATA XML 파싱(PHP 버전) 2023.01.12 270
263 PHP continue 문 file 2015.04.14 21097
262 php date 날짜 관련 함수 file 2021.03.27 411
261 PHP eregi가 빠를까, strpos가 빠를까? 2018.10.27 4091
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved