[php] 파일업로드 확장자 체크하기
자주필요한것 같아서 올려봅니다.
[출처] http://habony.tistory.com/219#.U3oAGtJ_trA
예제 (ex #1
| <?php $filename = "test.php."; $ext = array_pop(explode(".", strtolower($filename))); if(@ereg($ext, "php|php3|php4|htm|inc|html")){ echo "죄송합니다. php, html 파일은 업로드가 제한됩니다."; } ?> |
아무 문제가 없어 보이지만, 실은 php. 나 htm. gif. 등 모두 실행 가능한 파일임을 알아 둘 필요가 있습니다. 그러므로 다음 같이 한번더 체크해서 공격자가 우회하지 못하게 해주는게 좋습니다.
예제 (ex #2
| <?php $filename = "test.gif.bmp.php."; $ext = explode(".", strtolower($filename)); $cnt = count($ext)-1; if($ext[$cnt] === ""){ if(@ereg($ext[$cnt-1], "php|php3|php4|htm|inc|html")){ echo "죄송합니다. php, html 파일은 업로드가 제한됩니다."; } } else if(@ereg($ext[$cnt], "php|php3|php4|htm|inc|html")){ echo "죄송합니다. php, html 파일은 업로드가 제한됩니다."; } ?> |
댓글 2개
11년 전
파일 업로드시 확장자만 체크 하는것 말고
좀더 보안을 강화 할 수 있는 방법 없을 까요??
확장자 체크는 그냥 확장자만 바꾸면 되는 일인지라.
좀더 보안을 강화 할 수 있는 방법 없을 까요??
확장자 체크는 그냥 확장자만 바꾸면 되는 일인지라.
11년 전
그렇다면 mime type을 체크하면 될거 같습니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 11534 | |
| 11533 |
JavaScript
자바스크립트로 이미지 롤링 관련 문의드립니다.
|
| 11530 | |
| 11517 | |
| 11515 | |
| 11512 | |
| 11511 | |
| 11506 |
JavaScript
위지윅 에디터 만들때 선택영역 풀리는 문제
4
|
| 20681 | |
| 11504 | |
| 11503 |
기타
IE 구분하기
|
| 11502 |
기타
js, css 캐싱 팁
|
| 11501 | |
| 20679 | |
| 11500 |
JavaScript
롤링 배너 이해하는데 도움이 될것 같아 올립니다
|
| 11499 | |
| 11498 |
PHP
게시판 페이지 관련 글입니다.
|
| 11494 | |
| 11492 |
JavaScript
멀티 체크박스입니다.
1
|
| 11490 | |
| 11488 | |
| 11487 |
MySQL
mysqldump시 한글 깨짐문제..
|
| 20254 | |
| 20247 | |
| 20243 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기