php文件上传代码是什么? php文件上传代码

2019-04-28 08:25:10来源:华彩软件站 阅读 ()

新老客户大回馈,云服务器低至5折

(1)php文件上传代码就是通过 PHP,可以把文件上传到服务器。



创建一个文件上传表单

允许用户从表单上传文件是非常有用的。



 


PHP文件上传




请看下面这个供上传文件的 HTML 表单:

<html>

<body>


<form action="upload_file.php" method="post"

enctype="multipart/form-data">

<label for="file">Filename:</label>

<input type="file" name="file" id="file" />

<br />

<input type="submit" name="submit" value="Submit" />

</form>


</body>

</html>

请留意如下有关此表单的信息:

<form> 标签的 enctype 属性规定了在提交表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用 "multipart/form-data"。

<input> 标签的 type="file" 属性规定了应该把输入作为文件来处理。举例来说,当在浏览器中预览时,会看到输入框旁边有一个浏览按钮。

注释:允许用户上传文件是一个巨大的安全风险。请仅仅允许可信的用户执行文件上传操作。

创建上传脚本

"upload_file.php" 文件含有供上传文件的代码:

<?php

if ($_FILES["file"]["error"] > 0)

  {

  echo "Error: " . $_FILES["file"]["error"] . "<br />";

  }

else

  {

  echo "Upload: " . $_FILES["file"]["name"] . "<br />";

  echo "Type: " . $_FILES["file"]["type"] . "<br />";

  echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";

  echo "Stored in: " . $_FILES["file"]["tmp_name"];

  }

?>

通过使用 PHP 的全局数组 $_FILES,你可以从客户计算机向远程服务器上传文件。

第一个参数是表单的 input name,第二个下标可以是 "name", "type", "size", "tmp_name" 或 "error"。就像这样:

$_FILES["file"]["name"] - 被上传文件的名称

$_FILES["file"]["type"] - 被上传文件的类型

$_FILES["file"]["size"] - 被上传文件的大小,以字节计

$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称

$_FILES["file"]["error"] - 由文件上传导致的错误代码

这是一种非常简单文件上传方式。基于安全方面的考虑,您应当增加有关什么用户有权上传文件的限制。

上传限制

在这个脚本中,我们增加了对文件上传的限制。用户只能上传 .gif 或 .jpeg 文件,文件大小必须小于 20 kb:

<?php


if ((($_FILES["file"]["type"] == "image/gif")

|| ($_FILES["file"]["type"] == "image/jpeg")

|| ($_FILES["file"]["type"] == "image/pjpeg"))

&& ($_FILES["file"]["size"] < 20000))

  {

  if ($_FILES["file"]["error"] > 0)

    {

    echo "Error: " . $_FILES["file"]["error"] . "<br />";

    }

  else

    {

    echo "Upload: " . $_FILES["file"]["name"] . "<br />";

    echo "Type: " . $_FILES["file"]["type"] . "<br />";

    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";

    echo "Stored in: " . $_FILES["file"]["tmp_name"];

    }

  }

else

  {

  echo "Invalid file";

  }


?>

注释:对于 IE,识别 jpg 文件的类型必须是 pjpeg,对于 FireFox,必须是 jpeg。

保存被上传的文件

上面的例子在服务器的 PHP 临时文件夹创建了一个被上传文件的临时副本。

这个临时的复制文件会在脚本结束时消失。要保存被上传的文件,我们需要把它拷贝到另外的位置:

<?php

if ((($_FILES["file"]["type"] == "image/gif")

|| ($_FILES["file"]["type"] == "image/jpeg")

|| ($_FILES["file"]["type"] == "image/pjpeg"))

&& ($_FILES["file"]["size"] < 20000))

  {

  if ($_FILES["file"]["error"] > 0)

    {

    echo "Return Code: " . $_FILES["file"]["error"] . "<br />";

    }

  else

    {

    echo "Upload: " . $_FILES["file"]["name"] . "<br />";

    echo "Type: " . $_FILES["file"]["type"] . "<br />";

    echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";

    echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";


    if (file_exists("upload/" . $_FILES["file"]["name"]))

      {

      echo $_FILES["file"]["name"] . " already exists. ";

      }

    else

      {

      move_uploaded_file($_FILES["file"]["tmp_name"],

      "upload/" . $_FILES["file"]["name"]);

      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];

      }

    }

  }

else

  {

  echo "Invalid file";

  }

?>

上面的脚本检测了是否已存在此文件,如果不存在,则把文件拷贝到指定的文件夹。

注释:这个例子把文件保存到了名为 "upload" 的新文件夹。


(2)《php文件上传》程序员操作实例

 


 


这篇文章主要介绍了PHP文件上传实例代码,需要的朋友可以参考下


首先来看下上传部分的表单代码: 




代码如下:     <form method="post" action="upload.php" enctype="multipart/form-data">  

     <table border=0 cellspacing=0 cellpadding=0 align=center width="100%">  

      <tr>   

        <td width=55 height=20 align="center"><input type="hidden" name="MAX_FILE_SIZE" value="2000000">文件: </TD>  

        <td height="16">   

        <input name="file" type="file"  value="浏览" >             

        < input type="submit" value="上传" name="B1">  

        </td>  

      </tr>  

     </table>  

     </form> 


这里有几个要注意的地方,首先看这句<form method="post" action="upload.php" enctype="multipart/form-data">,这里我们采用POST方法,个别浏览器还支持PUT方法,当然这需要对脚本进行修改,我并不建议这么做。表单中必须设置enctype="multipart/form-data,这样,服务器就知道上传文件带有常规表单信息,记住,这个是必须设置的。此外还需要一个隐藏域来限制上传文件的最大长度:<input type="hidden" name="MAX_FILE_SIZE" value="2000000">,这里name必须设置成MAX_FILE_SIZE,其值就是上传文件的最大长度,单位是B,这里我限制成2M。再看这句:<input name="file" type="file"  value="浏览" >,type="file"说明了文件类型,这样一个基本的上传文件接口就完成了,接下来讲讲如何用PHP来处理上传的文件,此外你的php.ini中设置的上传文件最大长度可能会影响到你的实际上传,请根据实际情况修改,另PHP的上传是先传到临时目录,在移至指定目录的,了;临时目录的可根据需要修改,也可使用默认值。 

   好的,表单提交upload.php,来看看这个页面都有什么: 

PHP代码如下: 

代码如下:<?php  

 /*****************************************  

   Title :文件上传详解  

   Author:leehui1983(辉老大)  

   Finish Date  :2006-12-28  

  *****************************************/  

   $uploaddir = "./files/";//设置文件保存目录 注意包含/      

   $type=array("jpg","gif","bmp","jpeg","png");//设置允许上传文件的类型   

   $patch="http://127.0.0.1/cr_downloadphp/upload/files/";//程序所在路径  


   //获取文件后缀名函数  

      function fileext($filename)  

    {  

        return substr(strrchr($filename, '.'), 1);  

    }  

   //生成随机文件名函数      

    function random($length)  

    {  

        $hash = 'CR-';  

        $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';  

        $max = strlen($chars) - 1;  

        mt_srand((double)microtime() * 1000000);  

            for($i = 0; $i < $length; $i++)  

            {  

                $hash .= $chars[mt_rand(0, $max)];  

            }  

        return $hash;  

    }  

   $a=strtolower(fileext($_FILES['file']['name']));  

   //判断文件类型  

   if(!in_array(strtolower(fileext($_FILES['file']['name'])),$type))  

     {  

        $text=implode(",",$type);  

        echo "您只能上传以下类型文件: ",$text,"<br>";  

     }  

   //生成目标文件的文件名      

   else{  

    $filename=explode(".",$_FILES['file']['name']);  

        do  

        {  

            $filename[0]=random(10); //设置随机数长度  

            $name=implode(".",$filename);  

            //$name1=$name.".Mcncc";  

            $uploadfile=$uploaddir.$name;  

        }  

   while(file_exists($uploadfile));  

        if (move_uploaded_file($_FILES['file']['tmp_name'],$uploadfile)){  


            if(is_uploaded_file($_FILES['file']['tmp_name'])){  

                //输出图片预览  

                echo "<center>您的文件已经上传完毕 上传图片预览: </center><br><center><img src='$uploadfile'></center>";  

                echo"<br><center><a href='javascript:history.go(-1)'>继续上传</a></center>";  

              }  

              else{  

                echo "上传失败!";  

              }  

        }  

   }   

?>  

刚看这些你可能有点晕~~,不过不要紧,听我讲完,你就会发现其实这玩意SO EASY!!首先我讲下原理,该程序以上传图片为例,先判断文件类型是否为图片格式,若是则上传文件,以随机数和时间的组合重新命名文件(避免上传文件重名,这样做很有必要!),接着上传文件到指定目录,成功上传则输出上传的图片预览。这里要对程序中一些函数作些解释。先看return substr(strrchr($filename, '.'), 1), strrchar()函数有什么作用呢,我举个例子大家就知道,比如一个图片文件 pic.jpg,我们用 strrchr处理,strrchr(pic.jpg,'.'),它将返回.jpg,明白了吗?该函数返回指定字符在该字符串最后出现的位置后的字符。配合 substr() 我们就可以取到jpg,这样我们就得到了文件的后缀名,来判断上传文件是否符合指定格式。本程序把指定的格式放在一个数组中,实际使用时可根据需要添加。 

    接下来看产生随机数文件名部分, 我们看到mt_srand()这个函数,手册上叫他“播下一个更好的随机数发生器种子”,其实就是初始化一个随机数的函数,参数是(double)microtime() * 1000000,这里如果不这是参数就会自动设置个随机数,当然这不符合我们的需要,如此一来,随机数就具备一定的长度,保证了上传文件不重名。接着,我们调用判断文件类型的函数,并将其转化为小写strtolower(fileext($_FILES['file']['name'])),这里有个很关键的东东$_FILES ,这是个超级全局数组,保存了需要处理的表单数据,如果开启了register_globals,也可以直接访问,但这是不安全的。看刚才那个上传接口<input name="file" type="file"  value="浏览" >,根据这个表单名称,我们可以得到很多信息: 

    $_FILES['file']['name']--  得到文件名称 

    $_FILES['file']['tmp_name']--得到临时存储位置 

    $_FILES['file']['size']--得到文件大小 

    $_FILES['file']['type']--得到文件MIME类型 

得到这些信息,我们就可以轻松判断文件的信息了,是不是很方便?^_^,接下来还有一些函数需要了解,file_exists()--判断指定目录是否存在,不存在我们当然不能上传(好像是废话!),move_uploaded_file--将上传文件移至指定目录,is_uploaded_file--判断文件是否已经通过HTTP POST上传。成功上传,我们就输出预览,否则输出上传失败!




以上就是小编为大家介绍的PHP文件上传,如果您还在学习PHP的话可以收藏一下噢!


原文链接:http://www.huacolor.com/article/38188.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:电脑蓝屏故障0x00000018怎么办?电脑蓝屏故障

下一篇:Windows XP退役了怎么办?