html代碼:
<div id="images" > <h2><strong>圖片導入</strong></h2> <form enctype="multipart/form-data" action="./includer/importimg.inc.php?action=img" method="post" name="imge"> <input type="hidden" name="MAX_FILE_SIZE" value="100000000" /> <input value="導入文件" type="file" name="img" id="file"/><br/><br/> <input type="submit" id="imgbut" class="buttons" value="上傳圖片" /> </form> </div>
php代碼:
<?php /** *Mwbe Version1.0 *----------------------------------------------- *Copy 2013-2014 ylt *Web: communicate *----------------------------------------------- *Author: tao *Data: 2014-7-22 */ header("Content-Type:text/html;charset=utf-8"); //step 1 使用$_FILES['pic']["error"] 檢查錯誤 if(isset($_GET["action"])=="img"){ if($_FILES["img"]["error"] > 0){ switch($_FILES["img"]["error"]) { case 1: echo "<script type='text/javascript'>alert('上傳的文件超過了 php.ini 中 upload_max_filesize 選項限制的值<br>');history.back();</script>"; break; case 2: echo "<script type='text/javascript'>alert('上傳文件的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值');history.back();</script>"; break; case 3: echo "<script type='text/javascript'>alert('文件只有部分被上傳');history.back();</script>"; break; case 4: echo "<script type='text/javascript'>alert('沒有文件被上傳');history.back();</script>"; break; default: echo "<script type='text/javascript'>alert('末知錯誤');history.back();</script>"; } exit; } $maxsize=2000000; //50k //step 2 使用$_FILES["pic"]["size"] 限制大小 單位字節 2M=2000000 if($_FILES["img"]["size"] > $maxsize ) { echo "<script type='text/javascript'>alert('上傳的文件太大,不能超過{$maxsize}字節');history.back();</script>"; exit; } //step 3 使用$_FILES["pic"]["type"]或是文件的擴展名 限制類型 MIME image/gif image/png gif png jpg /* list($dl, $xl) = explode("/", $_FILES["pic"]["type"]); if($dl!="image"){ echo "請上傳一個圖片,不充許其它類型文件"; exit; } */ $allowtype=array("png", "gif", "jpg", "jpeg"); $arr=explode(".", $_FILES["img"]["name"]); $hz=$arr[count($arr)-1]; if(!in_array($hz, $allowtype)){ echo "<script type='text/javascript'>alert('這是不允許的類型');history.back();</script>"; exit; } //step 4 將讓傳後的文件名改名 $filepath="../imgweb/"; $fileimgweb="imgweb/";//為了符合UBB的路徑 $randname=date("Y").date("m").date("d").date("H").date("i").date("s").rand(100, 999).".".$hz; //將臨時位置的文件移動到指定的目錄上即可 if(is_uploaded_file($_FILES["img"]["tmp_name"])){ if(move_uploaded_file($_FILES["img"]["tmp_name"],$filepath.$randname)){ echo "<script type='text/javascript'>history.back();</script>"; session_start(); $_SESSION['images'] = $fileimgweb.$randname; }else{ echo "<script type='text/javascript'>alert('上傳失敗');history.back();</script>"; } }else{ echo"<script type='text/javascript'>alert('不是一個上傳文件');history.back();</script>"; } } ?>