php中上傳圖片文件,並且以上傳時的時間戳命名文件,並將文件的路徑存在session中以便使用。

html代碼:

<div id="images" style="width:250px;height:120px;background:#fff;border:1px solid #ccc;">    
    <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>";
	}	
}
?>


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章