• 회원가입
  • 로그인
  • 구글아이디로 로그인

[PHP-서기] php 40. 첨부파일 업로드 ★★★

1,376  


목차

  1. 파일 업로드 구현
  2. 파일 확장자 제한

 

파일 업로드 구현

 

1. form 태그 필수속성

 

<form action="업데이트실행파일(예: b.php)" method="post" enctype="multipart/form-data">

    <input type="file" name="hz">

    <input type="submit" value="확인"> 

</form>

 

 

2. phpinfo() 함수로 업로드 된 파일 확인하기

b.php

 

<?php phpinfo(); ?>



2. PHP Variables 영역에서 파일 정보 확인 가능. (※ 임시저장상태)
※ Ctrl + F (찾기창) 띄운 후, $_FILE 키워드로 검색

$_FILES['hz'] 배열변수 안에 아래 정보 등록

 

Array

(

    [name] => homzznag.txt

    [type] => text/plain

    [tmp_name] => C:\Users\kissh\AppData\Local\Temp\php40E6.tmp

    [error] => 0

    [size] => 791

)

 


PS1. b.php 파일에 아래 코드 넣어 바로 확인 가능.

<?php

foreach ($_FILES['hz'] as $k => $v) {

echo "파일 $k : $v <br>";

}

?>

 


PS2. b.php 파일에 아래 코드 넣어 바로 확인 가능.

 

<?php

echo "파일 name : ".$_FILES['hz']['name']."<br>";

echo "파일 type : ".$_FILES['hz']['type']."<br>";

echo "파일 tmp_name : ".$_FILES['hz']['tmp_name']."<br>";

echo "파일 error : ".$_FILES['hz']['error']."<br>";

echo "파일 size : ".$_FILES['hz']['size']."<br>";

?>

 

 

 

3. 임시파일을 실제 저장공간으로 이동시키기

b.php 파일에 아래 코드 추가

(예) /data/file 디렉토리로 이동시키기

 

<?php

// 방법1 - 업로드 파일명 그대로 사용. (보안 취약)

<?php

move_uploaded_file($_FILES['hz']['tmp_name'],'./data/file/'.$_FILES['hz']['name']);

?>

?>

 

<?php

// 방법2 - 업로드 파일명 변경 (예: fileNewName.txt) (보안 양호)

move_uploaded_file($_FILES['hz']['tmp_name'],'./data/file/fileNewName.txt');

?>

 

<?php

// 방법3 - 업로드 파일명을 날짜로 표현 (예: 14자리)

$newFileName = date('YmdHis'); // 년월일시분초

move_uploaded_file($_FILES['hz']['tmp_name'],'./data/file/'.$newFileName);

?>

 

PS. 아래 경우엔 에러 발생하니 주의.

  1. 해당 디렉토리 존재 안 한 경우
  2. 퍼미션이 707 (또는, 777) 아닌 경우

 

 

파일 확장자 제한

※ b.php 파일 상단에 아래 코드 추가

$hzfile = pathinfo($_FILES['hz']['name']);

// print_r($hzfile);

// 결과값: Array ( [dirname] => . [basename] => homzzang.txt [extension] => txt [filename] => homzzang )


switch($hzfile['extension'])

{

    case "jpg":

case "jpeg":

case "png";

    case "gif": break;


    case "": // 점(.)으로 끝나는 파일 제어

    case NULL: //확장자 없는 파일 제어

default: echo "(jpg/jpeg/png/gif) 이미지만 업로드 가능"; exit;

}

 



분류 제목
JS-생코 JS 46강 - UI,API 그리고 문서 (1/2) : 수업소개
JS-생코 JS 45강 - 모듈 (5/5) : 라이브러리의 사용
JS-생코 JS 44강 - 모듈 (4/5) : 라이브러리란?
JS-생코 JS 43강 - 모듈 (3/5) : Node.js의 모듈화
JS-생코 JS 42강 - 모듈 (2/5) : 모듈화
JS-생코 JS 41강 - 모듈 (1/5) : 모듈이란?
JS-생코 JS 40강 - 객체 (3/3) : 객체지향 프로그래밍
JS-생코 JS 39강 - 객체 (2/3) : 객체와 반복문의 조우
JS-생코 JS 38강 - 객체 (1/3) : 객체의 문법
JS-생코 JS 37강 - 배열 (5/5) : 제거와 정렬
JS-생코 JS 36강 - 배열 (4/5) : 데이터의 추가
JS-생코 JS 35강 - 배열 (3/5) : 배열과 반복문의 조우
JS-생코 JS 34강 - 배열 (2/5) : 배열의 효용
JS-생코 JS 33강 - 배열 (1/5) : 배열의 문법
JS-생코 JS 32강 - 함수 (5/5) : 다양한 정의 방법
JS-생코 JS 31강 - 함수 (4/5) : 출력
JS-생코 JS 30강 - 함수 (3/5) : 입력
JS-생코 JS 29강 - 함수 (2/5) : 함수의 효용
JS-생코 JS 28강 - 함수 (1/5) : 함수란?
JS-생코 JS 27강 - 반복 (6/6) : 반복문의 중첩 (= 이중 반복문) ★★★★★
25/35
목록
찾아주셔서 감사합니다. Since 2012