我再上传的时候,程序提示上传成功,但是服务器上却没有上传的文件,这是什么原因?

解决方案 »

  1.   

    我上次也遇到过一个类似的问题
    当时是我访问
    http://servername/ajax/upload.php
    然后这PHP文件里的path写成了"upload/"
    然后我的本意是上传到
    D:\www\upload文件夹下
    然后发现上传成功,可是在D:\www\upload里却看不到,以为哪里出了问题...记过...
    原来是传到
    D:\www\ajax\upload里了...
    path写错了...应该是"../upload/"
    我估计你大概也是犯了和我同样的错吧...
      

  2.   

    两个可能的原因:1. 要注意上传文件名中文乱码的情况,要注意文件名转码;2. 上传的文件夹是否有读写的权限。
    PHP 文件上传
    Previous Page Next Page 通过 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:<?phpif ((($_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" 的新文件夹。
      

  3.   

    PHP文件上传全攻略这是一篇比较老的文章,其实从情感上来说,我更愿意推荐手册上的介绍,但事实上,在一些PHP群中,有些朋友在问的时候,他们总是想不到翻手册的。嗯,英文的手册确实让人不太舒服,但,不可能在手册一出来就帮你翻译好的吧?事事都去期待别人,还不如把英文好好看看,再者,手册上的英文真的很简单的。
    我不知道你们的手册是怎么样的,版本多少,但是我在我的手册里是有这么一个章节:Chapter 38. Handling file uploads
    POST method uploads   
    Error Messages Explained   
    Common Pitfalls   
    Uploading multiple files   
    PUT method support   一共讲了5种情况,而且对于不能上传大文件也专门做了介绍,他是这么说的:PHP is capable of receiving file uploads from any RFC-1867 compliant browser (which includes Netscape Navigator 3 or later, Microsoft Internet Explorer 3 with a patch from Microsoft, or later without a patch).Related Configurations Note: See also the file_uploads, upload_max_filesize, upload_tmp_dir, post_max_size and max_input_time directives in php.iniPHP also supports PUT-method file uploads as used by Netscape Composer and W3C's Amaya clients. See the PUT Method Support for more details.OK,我知道你们不愿意看,所以我也不多说了,看中文版吧,原文来自于:http://www.sourcejoy.com/php_dev/PHP_upload.html。
    PHP文件上传功能一般都是大家使用事先封装好的函数,要用的时候直接使用已封装的函数就完了,但有时候不能使用封装函数,还真不大能记住PHP的上传相关的东西,在此做个总结,以备后用。1.表单部分
    允许用户上传文件,在HTML表单的声明中要加上一个上传的属性:
    enctype = 'multipart/form-data'
    表单的method必须是POST
    表单选项MAX_FILE_SIZE隐藏域用于限制上传文件大小,它必须放在文件表单元素前面,单位为字节。
    如:
    <form enctype='multipart/form-data' id='aa' name='aaa' method='post' action='xxx.php'>
    <input type='hidden' name='MAX_FILE_SIZE' value='2621114' />
    <input name='upload_file' type='file' />
    </form>2.处理上传文件
    上传时,PHP收到关于该文件的信息数组,这些信息可以在$_FILES这个超级全局数组中找到。
    如:如果表单中的文件输入框名字为upload_file,那么关于该文件的所有信息都包含在数组$_FILES['upload_file']里面。
    如:客户上传了一个“aaa.jpg”的图片数组值如下:
    name "p5pp.jpg" 上传时文件的名字
    type “image/jpeg" 文件类型
    tmp_name "/tmp/phpjksdf" 服务器端的临时文件名
    error 上传错误的返回值
    size 2045 文件实际大小上面数组里面的error会返回不同的常量值,如下:
    UPLOAD_ERR_OK 没有错误发生,文件上传成功
    UPLOAD_ERR_INI_SIZE 文件大小超过了PHP.INI中upload_max_filesize选项限制的值
    UPLOAD_ERR_FORM_SIZE 上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项值。可在程序中检查表单$FILES ['up_file']['size']来处理
    UPLOAD_ERR_PARTIAL 文件只有部分被上传
    UPLOAD_ERR_NO_FILE 用户没有提供任何文件上传
    上传后处理的具体例子:
    if(!move_uploaded_file($_FILES['f']['tmp_name'],"uploads/".$_FILES['f']['name'].".jpg")){
    echo "error";
    }函数:
    move_uploaded_file 移动上传的临时文件到指定的目录下
    例子:
    move_uploaded_file('临时文件名','指定文件路径')is_uploaded_file 判断是否是通过http Post上传的文件
    例子:
    if(!is_uploaded_file($_FILES['f']['tmp_name'])){
    echo '非法';
    }3.相关参数
    PHP上传设计到的php.ini中的参数:
    file_uploads 是否允许上传文件,默认ONupload_tmp_dir 上传文件防止的临时目录,未指定则使用系统默认位置upload_max_filesize 允许上传文件的大小的最大值,默认为2Mpost_max_size 控制采用POST方法进行一次表单提交中PHP所能接受的最大数据量,如果希望用PHP文件上传,则此值要改为比upload_max_filesize要大max_input_time 以秒为单位对通过POST/GET/PUT方式接受数据时间进行限制。memory_limit 为了避免正在运行的脚本大量使用系统内存,PHP允许定义内存使用限额。通过设置此参数来制定单个脚本程序可以使用的最大内存容量,应适当大于post_max_size值max_execution_time 用来设置在强制终止脚本前PHP等待脚本执行完毕的时间,单位秒。次选项可限制死循环脚本,但当存在一个长时间的合法活动时(如:上传大文件),这项功能也会导致操作失败。这样情况下必须考虑将此变量增加。4.考虑多文件上传
    可以利用$_FILES数组就可以轻松实现多文件上传。$_FILES数组可以获取客户端表单里面所有的file域内容,从而获得所有在同一表单上传的文件。5.突破上传的内存限制
    方法一:
    修改php.ini中memory_limit值,改为更大,如 64M
    方法二:
    使用Apache Rewrite方法,动态修改memory_limit的值。首先建立一个.htaccess文件,保存在上传文件程序的 当前目录即可.代码如下:
    php_value memory_limit 100M
    php_value post_max_size 30M
    php_value upload_max_filesize 30M
    php_value max_execution_time 300
    php_value max_input_tim 300
    php_value display_errors On
    ——EOF——
    当然,如果你在这种下也还是看不懂不能理解的话,我也就没有话说喽。
      

  4.   

    是我php.ini 设置问题,谢谢楼上的解答