PHP上传文件,AJAX文件上传

    <form name="form1" id="form1" method="post" enctype="multipart/form-data">
    <p>导入文件:    
        <input type="file" name="fileToUpload" id="fileToUpload"/>
        <input type="submit" id="upload" name="upload" onClick="thisAction()" value="上传" /></p>

   </form>  

 

if(isset($_POST['upload'])){

   $file = $_FILES ['fileToUpload'];

    $uploaddir = '/tmp/';
    $uploadfile = $uploaddir . basename($file['name']);
    move_uploaded_file ($file ["tmp_name"], $uploadfile );
    echo "上传文件成功,文件名不变,存放在/tmp/目录下";
}

如果要固定上传后的文件名则用以下代码:

if(isset($_POST['upload'])){
    $file = $_FILES ['fileToUpload'];
    $uploadfile = "/tmp/uploadfile_tmp_name.csv";
    move_uploaded_file ($file ["tmp_name"], $uploadfile );
    echo "上传文件成功,上传后的文件以uploadfile_tmp_name.csv命名,存放在/tmp/目录下";
}

【AJAX文件上传】

其实就是实现无刷新式的文件上传。可采用IFRAME文件上传原理。
实际上在用PHP上传文件时。。。只能用$_FILES形式,但是若我们只是单一的用JS方式取其ID,如<input id='img' type='file'>..document.getElementById('img').value或者jquery形式的$("#img")都是不能正真实际上传的(但是还是有很多人这样做,刚开始时我也是)。
可是功能上又要要求实现所谓的“异步上传”,怎么办呢??只能借助于第三方的组件,或者自己写一个(在网页里嵌入一个IFRAME)。但如果是考虑开发时间,那以用第三方的,这里有一个不错的jQuery的Ajax文件上传的组件,是“ajaxfileupload.js",其组件下载地址为:
http://www.phpletter.com/,下载完毕里面有一个php的应用demo,很容易看懂的。
过程:
(1 )前端上文件的代码: test.php       

    <script type="text/javascript" src="jquery.js"></script>
    <script type="text/javascript" src="ajaxfileupload.js"></script>
    <script type="text/javascript">
       function ajaxFileUpload()
               {
                  $.ajaxFileUpload
                     (
                       {
                           
url:'doajaxfileupload.php', //你处理上传文件的服务端
                            secureuri:false,
                            fileElementId:'img',
                            dataType: 'json',
                            success: function (data)
                                  {
                                    alert(data.file_infor);
                                  }
                               }
                         )

                       return false;
                 }
     </script>
相应的HTML为:
        <input id="img" type="file" size="45" name="img" class="input">
        <button class="button" id="buttonUpload" onclick="return ajaxFileUpload();">Upload</button>

这样客户端就完成了。
        
(2) 再服务器端时   doajaxfileupload.php

   此处为了简便的检测是否真正的传值过来了,你可以将它存起来了。
             $file_infor = var_export($_FILES,true);
             file_put_contents("d:file_infor.php".$file_infor);

   这样你打来刚生成的file_infor.php文件时,你又看到了熟悉的信息了:
     array(
             'name'=>'lamp.jpg',
             'type'=>'image/pjpeg',
             'tmp_name'=>'c:/windows/temp/phpFA.tmp',
             'error'=>0,
             'size'=>3127
         )
当然,真正的处理类于这样的:
  
<?php
     $upFilePath = "d:/";
    
$ok=@move_uploaded_file($_FILES['img']['tmp_name'],$upFilePath);
   if($ok === FALSE){
    echo json_encode('file_infor'=>'上传失败');
   }else{
    echo json_encode('file_infor'=>'上传成功');
   }
   ?>   
另注:实际上,你可以在一个页面里嵌入一个IFRAME,然后在IFRAME使用原生的POST表单提交.JQUERY的这个插件也是采用了这种方式。只不过它是动态生成的IFRAME 与表单


参考: http://blog.csdn.net/FC_LAMP/article/details/4273237

http://www.phpletter.com/DOWNLOAD/

Jquery Ajax File Uploader


Jquery Ajax File Uploader Version 2.1
相关文章
相关标签/搜索