萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> php上傳圖片學習筆記與心得

php上傳圖片學習筆記與心得

我們在php中上傳文件就必須使用#_FILE變量了,這個自動全局變量 $_FILES 從 PHP 4.1.0 版本開始被支持。在這之前,從 4.0.0 版本開始,PHP 支持 $HTTP_POST_FILES 數組。這些數組將包含所有關於您上傳的文件的信息,其中,我們推薦您使用 $_FILES。

如果 PHP 的設置選項 register_globals 為 on,則相關的變量名將也會存在。從 PHP 4.2.0 版本開始,register_globals 的默認值被設為 off。

我們假設文件上傳字段的名稱為 userfile。名稱可隨意命名。

$_FILES['userfile']['name']
客戶端機器文件的原名稱。

$_FILES['userfile']['type']
文件的 MIME 類型,需要浏覽器提供該信息的支持,例如“image/gif”。

$_FILES['userfile']['size']
已上傳文件的大小,單位為字節。

$_FILES['userfile']['tmp_name']
文件被上傳後在服務端儲存的臨時文件名。

$_FILES['userfile']['error']
和該文件上傳相關的錯誤代碼。['error'] 是在 PHP 4.2.0 版本中增加的。

處理函數:

move_uploaded_file()
(PHP 4 >= 4.0.3, PHP 5)

move_uploaded_file -- 將上傳的文件移動到新位置

說明
bool move_uploaded_file ( string filename, string destination )

本函數檢查並確保由 filename 指定的文件是合法的上傳文件(即通過 PHP 的 HTTP POST 上傳機制所上傳的)。如果文件合法,則將其移動為由 destination 指定的文件。

如果 filename 不是合法的上傳文件,不會出現任何操作,move_uploaded_file() 將返回 FALSE。

如果 filename 是合法的上傳文件,但出於某些原因無法移動,不會出現任何操作,move_uploaded_file() 將返回 FALSE。此外還會發出一條警告。

如果目標文件已經存在,將會被覆蓋。

示例:

 代碼如下 復制代碼 if(move_uploaded_file($_FILES["magfile"]["tmp_name"], $uploaddir))
  {
    echo "Update OK!";
  }

也可用copy(PHP 3, PHP 4, PHP 5)
copy -- 拷貝文件
bool copy ( string source, string dest )

將文件從 source 拷貝到 dest。如果成功則返回 TRUE,失敗則返回 FALSE。

提交頁:

 代碼如下 復制代碼

<form action="." method="post" enctype="multipart/form-data" name="UL"> 
<!--這裡的‘enctype="multipart/form-data" ’是必須的--> 
<input type="file" name="picurl" size="15" 
accept="image/x-png,image/gif,image/jpeg"> 
<input type="submit" name="upload" value="上傳"> 
</form>

處理頁:

 代碼如下 復制代碼

    if($_FILES['picurl']['size'] > 0){
      if(move_uploaded_file ($_FILES['picurl']['tmp_name'], $_FILES['picurl']['name'])){
        echo "圖片上傳成功";
      }
    }

其它非File類型的表單,可照樣用$_POST['name']來接收。

php上傳圖片簡單實現

 代碼如下 復制代碼 <html> 
<head> 
<title>PHP上傳圖片簡單實現 </title> 
</head> 
<body> 
<?php 
if($_GET['action'] == 'upfile') 

$target_path = 'temp_'.$_FILES['photo']['name']; 
echo '上傳的臨時文件:' .$_FILES['photo']['tmp_name'] . '<br/>';
echo '上傳的目標文件:' .$target_path . '<br/>';
echo $_SERVER["SCRIPT_FILENAME"] . '<br/>';
echo $_SERVER["OS"] . '<br/>';
//測試函數: move_uploaded_file
//也可以用函數:copy
move_uploaded_file($_FILES['photo']['tmp_name'], $target_path); 
echo "Upload result:"; 
if(file_exists($target_path)) { 
 if($_SERVER["OS"]!="Windows_NT"){
  @chmod($target_path,0604);
 }
 echo '<font color="green">Succeed!</font><br /><a href="http://' .$_SERVER["SERVER_NAME"] . "/" .$target_path .'"><img src=' .$target_path .' border="0">'; 
} else { 
 echo '<font color="red">Failed!</font>'; 

exit; 

?> 
<h1>Registration</h1> 
<form action="upload.php?action=upfile" method="post" name="UForm" enctype="multipart/form-data"> 
<fieldset> 
<legend>Your information</legend> 
<ul> 
<li>Your Phot<input type="file" name="photo"></li> 
</ul> 
</fieldset> 
<button type="submit">上傳</button> 
</form> 
</body> 
</html>

上面代碼只適用於學習使用,如果想使用在現在的服務器上我們必須如下寫法

 代碼如下 復制代碼

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<?php
/******************************************************************************

參數說明:
$max_file_size  : 上傳文件大小限制, 單位BYTE
$destination_folder : 上傳文件路徑
$watermark   : 是否附加水印(1為加水印,其他為不加水印);

使用說明:
1. 將PHP.INI文件裡面的"extension=php_gd2.dll"一行前面的;號去掉,因為我們要用到GD庫;
2. 將extension_dir =改為你的php_gd2.dll所在目錄;
******************************************************************************/

//上傳文件類型列表
$uptypes=array(
    'image/jpg',
    'image/jpeg',
    'image/png',
    'image/pjpeg',
    'image/gif',
    'image/bmp',
    'image/x-png'
);

$max_file_size=2000000;     //上傳文件大小限制, 單位BYTE
$destination_folder="uploadimg/"; //上傳文件路徑
$watermark=1;      //是否附加水印(1為加水印,其他為不加水印);
$watertype=1;      //水印類型(1為文字,2為圖片)
$waterposition=1;     //水印位置(1為左下角,2為右下角,3為左上角,4為右上角,5為居中);
$waterstring="http://www.111cn.net/";  //水印字符串
$waterimg="xplore.gif";    //水印圖片
$imgpreview=1;      //是否生成預覽圖(1為生成,其他為不生成);
$imgpreviewsize=1/2;    //縮略圖比例
?>
<html>
<head>
<title>ZwelL圖片上傳程序</title>
<style type="text/css">
<!--
body
{
     font-size: 9pt;
}
input
{
     background-color: #66CCFF;
     border: 1px inset #CCCCCC;
}
-->
</style>
</head>

<body>
<form enctype="multipart/form-data" method="post" name="upform">
  上傳文件:
  <input name="upfile" type="file">
  <input type="submit" value="上傳"><br>
  允許上傳的文件類型為:<?=implode(', ',$uptypes)?>
</form>

<?php
if ($_SERVER['REQUEST_METHOD'] == 'POST')
{
    if (!is_uploaded_file($_FILES["upfile"][tmp_name]))
    //是否存在文件
    {
         echo "圖片不存在!";
         exit;
    }

    $file = $_FILES["upfile"];
    if($max_file_size < $file["size"])
    //檢查文件大小
    {
        echo "文件太大!";
        exit;
    }

    if(!in_array($file["type"], $uptypes))
    //檢查文件類型
    {
        echo "文件類型不符!".$file["type"];
        exit;
    }

    if(!file_exists($destination_folder))
    {
        mkdir($destination_folder);
    }

    $filename=$file["tmp_name"];
    $image_size = getimagesize($filename);
    $pinfo=pathinfo($file["name"]);
    $ftype=$pinfo['extension'];
    $destination = $destination_folder.time().".".$ftype;
    if (file_exists($destination) && $overwrite != true)
    {
        echo "同名文件已經存在了";
        exit;
    }

    if(!move_uploaded_file ($filename, $destination))
    {
        echo "移動文件出錯";
        exit;
    }

    $pinfo=pathinfo($destination);
    $fname=$pinfo[basename];
    echo " <font color=red>已經成功上傳</font><br>文件名:  <font color=blue>".$destination_folder.$fname."</font><br>";
    echo " 寬度:".$image_size[0];
    echo " 長度:".$image_size[1];
    echo "<br> 大小:".$file["size"]." bytes";

    if($watermark==1)
    {
        $iinfo=getimagesize($destination,$iinfo);
        $nimage=imagecreatetruecolor($image_size[0],$image_size[1]);
        $white=imagecolorallocate($nimage,255,255,255);
        $black=imagecolorallocate($nimage,0,0,0);
        $red=imagecolorallocate($nimage,255,0,0);
        imagefill($nimage,0,0,$white);
        switch ($iinfo[2])
        {
            case 1:
            $simage =imagecreatefromgif($destination);
            break;
            case 2:
            $simage =imagecreatefromjpeg($destination);
            break;
            case 3:
            $simage =imagecreatefrompng($destination);
            break;
            case 6:
            $simage =imagecreatefromwbmp($destination);
            break;
            default:
            die("不支持的文件類型");
            exit;
        }

        imagecopy($nimage,$simage,0,0,0,0,$image_size[0],$image_size[1]);
        imagefilledrectangle($nimage,1,$image_size[1]-15,80,$image_size[1],$white);

        switch($watertype)
        {
            case 1:   //加水印字符串
            imagestring($nimage,2,3,$image_size[1]-15,$waterstring,$black);
            break;
            case 2:   //加水印圖片
            $simage1 =imagecreatefromgif("xplore.gif");
            imagecopy($nimage,$simage1,0,0,0,0,85,15);
            imagedestroy($simage1);
            break;
        }

        switch ($iinfo[2])
        {
            case 1:
            //imagegif($nimage, $destination);
            imagejpeg($nimage, $destination);
            break;
            case 2:
            imagejpeg($nimage, $destination);
            break;
            case 3:
            imagepng($nimage, $destination);
            break;
            case 6:
            imagewbmp($nimage, $destination);
            //imagejpeg($nimage, $destination);
            break;
        }

        //覆蓋原上傳文件
        imagedestroy($nimage);
        imagedestroy($simage);
    }

    if($imgpreview==1)
    {
    echo "<br>圖片預覽:<br>";
    echo "<img src="".$destination."" width=".($image_size[0]*$imgpreviewsize)." height=".($image_size[1]*$imgpreviewsize);
    echo " alt="圖片預覽:r文件名:".$destination."r上傳時間:">";
    }
}
?>
</body>
</html>

copyright © 萬盛學電腦網 all rights reserved