파일업로드 하는 곳의 보안문제좀 알려주세요 ^^

사이트에 요상한 업로드파일이 올라와서 말썽입니다 ㅠㅠ

업로드 하는 곳에 파일명검사(제한)를 하면 된다는 팁을 얻었는데요.

보통 어떤 파일만 올라가도록 하시는지 고수님들의 팁을 듣고싶습니다. 도와주세요 ㅠㅠ
|

댓글 4개

#cat > .htaccess
php_admin_flag engine off
#chmod 404 .htaccess
if($_FILES['upload_file']['name'][$i]){//if 1
$file=$_FILES['upload_file']['tmp_name'][$i];
$file_name=$_FILES['upload_file']['name'][$i];
$file_size=$_FILES['upload_file']['size'][$i];
$file_name_div=explode(".",$file_name);
$file_dot_check=$file_name_div[sizeof($file_name_div)-1];
if($file_size=="0") message("업로드".($i+1)."에 업로드하실 파일의 경로가 올바르지 않습니다.","-1");
if(preg_match("/.php$|.ph$|.php3$|.php4$|.jsp$|.asp$|.pl$|.js$|.html$|.htm$|.phtml$|.shtm$|.ztx$|.dot$|.cgi$|.inc$|.txt$|.exe$|.com$|.bat$/i", $_FILES['upload_file']['name'][$i]) || substr($_FILES['upload_file']['name'][$i],0,1)=='.'){
message("업로드가 불가능한 파일(확장자)입니다.\\n\\n파일을 압축하여 업로드를 하시기 바랍니다.","-1");
}
}

구닥다리지만 잘 돌갑니다.
우선 정책을 정하셔야 될 것 같은데요.
업로드시 어떤 파일들만 허락할 것인지 용도가 무엇인지
따라서 제한을 해야 될 것 같습니다.
이미지만 업로드하는 게시판이 있을 수도 있고 문서파일만 업로드 할 수 있을 수도 있고
그리고 업로드 제한을 서버단에서 할 수도 있고 클라이언트 자바스크립트에서도 제어할 수도 있습니다.
이점 유의해서 작업을 하시면 될 것 같네요.
좋은 말씀 갑사합니다 ^^
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
15년 전 조회 1,137
15년 전 조회 1,477
15년 전 조회 1,275
15년 전 조회 1,314
15년 전 조회 1,610
15년 전 조회 1,179
15년 전 조회 1,219
15년 전 조회 1,140
15년 전 조회 1,295
15년 전 조회 1,127
15년 전 조회 1,567
15년 전 조회 1,269
15년 전 조회 1,226
15년 전 조회 1,441
15년 전 조회 1,132
15년 전 조회 1,191
15년 전 조회 1,120
15년 전 조회 1,335
15년 전 조회 1,136
15년 전 조회 1,264
15년 전 조회 1,222
15년 전 조회 1,510
15년 전 조회 1,141
15년 전 조회 1,299
15년 전 조회 1,275
15년 전 조회 1,582
15년 전 조회 1,857
15년 전 조회 1,219
15년 전 조회 1,355
15년 전 조회 1,260
15년 전 조회 1,398
15년 전 조회 1,252
15년 전 조회 1,409
15년 전 조회 1,314
15년 전 조회 1,331
15년 전 조회 1,216
15년 전 조회 4,206
15년 전 조회 7,298
15년 전 조회 1,442
15년 전 조회 1,218
15년 전 조회 1,571
15년 전 조회 1,367
15년 전 조회 1,440
15년 전 조회 1,275
15년 전 조회 1,159
15년 전 조회 1,588
15년 전 조회 1,251
15년 전 조회 1,799
15년 전 조회 1,579
15년 전 조회 1,370
15년 전 조회 1,343
15년 전 조회 1,218
15년 전 조회 1,554
15년 전 조회 1,262
15년 전 조회 3,358
15년 전 조회 1,553
15년 전 조회 1,473
15년 전 조회 1,622
15년 전 조회 1,203
15년 전 조회 1,491
15년 전 조회 1,684
15년 전 조회 1,375
15년 전 조회 2,135
15년 전 조회 1,178
15년 전 조회 1,354
15년 전 조회 1,639
15년 전 조회 1,443
15년 전 조회 1,168
15년 전 조회 3,390
15년 전 조회 1,583
15년 전 조회 2,566
15년 전 조회 2,454
15년 전 조회 1,508
15년 전 조회 2,755
15년 전 조회 1,326
15년 전 조회 1,841
15년 전 조회 3,022
15년 전 조회 1,204
15년 전 조회 1,753
15년 전 조회 1,968
15년 전 조회 1,327
15년 전 조회 1,643
15년 전 조회 1,204
15년 전 조회 2,434
15년 전 조회 1,822
15년 전 조회 1,326
15년 전 조회 1,004
15년 전 조회 1,101
15년 전 조회 1,513
15년 전 조회 1,600
15년 전 조회 1,017
15년 전 조회 918
15년 전 조회 1,202
15년 전 조회 1,133
15년 전 조회 2,160
15년 전 조회 1,011
15년 전 조회 1,047
15년 전 조회 1,046
15년 전 조회 1,281
15년 전 조회 2,151