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

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

1,731  


목차

  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 86강 - 상속 (2/3) : 상속의 사용방법
JS-생코 JS 85강 - 상속 (1/3) : 상속이란?
JS-생코 JS 84강 - this (5/5) : apply와 this
JS-생코 JS 83강 - this (4/5) : 객체로서 함수
JS-생코 JS 82강 - this (3/4) : 생성자와 this
JS-생코 JS 81강 - this (2/5) : 메소드와 this
JS-생코 JS 80강 - this (1/5) : 함수와 this
JS-생코 JS 79강 - 전역객체
JS-생코 JS 78강 - 생성자와 new (3/3) : 생성자와 new
JS-생코 JS 77강 - 생성자와 new (2/3) : 객체생성
JS-생코 JS 76강 - 생성자와 new (1/3) : 소개
JS-생코 JS 75강 - 객체지향프로그래밍 (3/3) : 부품화
JS-생코 JS 74강 - 객체지향프로그래밍 (2/3) : 추상화
JS-생코 JS 73강 - 객체지향프로그래밍 (1/3) : 오리엔테이션
JS-생코 JS 72강 - 함수의 호출 (2/2) : apply의 사용
JS-생코 JS 71강 - 함수의 호출 (1/2) : apply 소개
JS-생코 JS 70강 - arguments (2/2) : function length
JS-생코 JS 69강 - arguments (1/2) : arguments란?
JS-생코 JS 68강 - 클로저 (closure) 4/4 : 클로저의 응용
JS-생코 JS 67강 - 클로저 (closure) 3/4 : private variable
23/35
목록
찾아주셔서 감사합니다. Since 2012