이 코드를 작성했지만 문제가 있습니다. 다른 사람이 제출 한 파일을 업로드 할 때 업로드 된 파일이 없는지 확인할 수 없으며 허용 된 외부 파일 (예 : ".jpg")을 지정할 수 없습니다. "foreach"에서 어떻게 할 수 있습니까? 하나의 이미지 만 업로드 할 때이 작업을 수행 할 수 있지만 멀티 업로드의 경우이 코드를 사용하면 폼에 배열을 사용했음을 눈치 챘을 것입니다.
<?php
mysql_connect('localhost','root','root')or die (mysql_error());
mysql_select_db('storeimage');
?>
<?
if ($_POST['submit']){
$file=$_FILES['file'];
$name=$_FILES['file']['name'];
$tmp_name=$_FILES['file']['tmp_name'];
foreach($name as $key=>$value){
$name_file=$name[$key];
$tmp_file=$tmp_name[$key];
$imgpath = rand().'.jpeg';
move_uploaded_file($tmp_file,'images/'.$imgpath);
$insert=mysql_query("insert into imagelocation values('','images/$imgpath')")or die (mysql_error());
$id=mysql_insert_id();
$select=mysql_query("select * from imagelocation where id='$id' ");
while ($row=mysql_fetch_object($select)){
echo "<center><img src='$row->images'/></center><br/>";
}
}
}
?>
<form action='' method='post' enctype='multipart/form-data'>
<input type='file' name='file[]' multiple />
<input type='submit' name='submit'/>
</form>
같은 것을 할 필요가 여러 개의 파일로 작업
– Spudley스택 오버플로에 오신 것을 환영합니다! 새로운 코드를 작성하기 위해 mysql_ * 함수를 사용하지 마십시오. 더 이상 유지 관리되지 않으며 커뮤니티가 [지원 중단 프로세스] (http://goo.gl/KJveJ)를 시작했습니다. * [빨간색 상자] (http://goo.gl/GPmFd) *를 참조하십시오. 대신 [prepared statements] (http://goo.gl/vn8zQ)에 대해 알아야하고 [PDO] (http://php.net/pdo) 또는 [MySQLi] (http://php.net/)를 사용해야합니다. mysqli). 어떤 것을 결정할 수 없다면 [이 기사] (http://goo.gl/3gqF9)가 도움이 될 것입니다. PDO를 선택하면 [여기는 좋은 가이드입니다] (http://goo.gl/vFWnC). –
당신은 공백에 대한 강력한 혐오감을 가지고 있어야합니다 :) –