当前位置:首页 > CMS教程 > Thinkphp > 列表

ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-04-19 11:07:07 浏览: 评论:0 

这篇文章主要介绍了ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法,是ThinkPHP文件上传中一个比较典型的应用技巧,非常具有实用价值,需要的朋友可以参考下

本文实例讲述了ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法。分享给大家供大家参考。具体实现方法分析如下:

首先,AjaxFileUploader插件是一个基于jquery的插件,我们可以使用AjaxFileUploader插件来实现文件异步上传功能了,使用这款插件上传文件不要担心兼容性的问题,它的兼容性可以说兼容所有主流浏览器,下面来给大家介绍一个AjaxFileUploader+thinkphp实现文件上传的实例。

ThinkPHP框架下用AjaxFileUploader插件实现ajax文件上传,支持多种文件格式,页面无刷新上传。

在Lib/Action/目录下创建upAction.class.php文件,代码如下:

  1. <?php 
  2. class upAction extends BaseAction{ 
  3. public function index(){ 
  4.     $this->display(); 
  5.  
  6. /* 
  7. *@文件上传 
  8. *@author    FineYi 
  9. *@date        2013-01-23 
  10. */ 
  11. public function upLoadFile(){ 
  12.     $error = ""
  13.     $msg = ""
  14.     $fileElementName = 'fileToUpload'
  15.     if(!emptyempty($_FILES[$fileElementName]['error'])){ 
  16.         switch($_FILES[$fileElementName]['error']){ 
  17.             case '1'
  18.                 $error = 'The uploaded file exceeds the upload_max_filesize directive in php.ini'
  19.                 break
  20.             case '2'
  21.                 $error = 'The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form'
  22.                 break
  23.             case '3'
  24.                 $error = 'The uploaded file was only partially uploaded'
  25.                 break
  26.             case '4'
  27.                 $error = 'No file was uploaded.'
  28.                 break
  29.  
  30.             case '6'
  31.                 $error = 'Missing a temporary folder'
  32.                 break
  33.             case '7'
  34.                 $error = 'Failed to write file to disk'
  35.                 break
  36.             case '8'
  37.                 $error = 'File upload stopped by extension'
  38.                 break
  39.             case '999'
  40.             default
  41.                 $error = 'No error code avaiable'
  42.         } 
  43.     }elseif(emptyempty($_FILES['fileToUpload']['tmp_name']) || $_FILES['fileToUpload']['tmp_name'] == 'none'){ 
  44.         $error = 'No file was uploaded..'
  45.     }else
  46.             $re = $this->up(); 
  47.             if(!$re){ 
  48.                 $error = 'Up file fail'
  49.             } 
  50.             $msg = $re['savename'];    //文件名 
  51.             $path = '/upload/bizcoop/'.$msg;    //文件路径 
  52.             $size = $re['size'];    //文件大小 
  53.     }        
  54.     echo json_encode(array('error'=>$error,'msg'=>$msg,'path'=>$path,'size'=>$size));exit
  55.  
  56. private function up(){ 
  57.     import('@.Org.UploadFile');//将上传类UploadFile.class.php拷到Lib/Org文件夹下 
  58.     $upload=new UploadFile(); 
  59.  
  60.     $upload->maxSize='-1';//默认为-1,不限制上传大小 
  61.     $upload->savePath= ICTSPACE_DIST_ROOT_PATH.'/www/upload/bizcoop/';//保存路径 
  62.     $upload->saveRule=uniqid;//上传文件的文件名保存规则 
  63.     $upload->uploadReplace=true;//如果存在同名文件是否进行覆盖 
  64.     $upload->allowExts=array('jpg','jpeg','png','gif');//准许上传的文件类型 
  65.     if($upload->upload()){ 
  66.         $info=$upload->getUploadFileInfo(); 
  67.         return $info[0]; 
  68.     }else
  69.         return false; 
  70.         exit
  71.     } 
  72. ?> 

在/Tpl/default/Up/目录下创建index.tpl文件,代码如下:

  1. <div id="content"
  2. <h1>Ajax File Upload Demo</h1> 
  3. <img id="loading" style="display: none;" alt="" src="__APP____PUBLIC__/style/img/loading.gif" /> 
  4.  
  5. <form action="" enctype="multipart/form-data" method="POST" name="form"
  6. <table class="tableForm" cellspacing="0" cellpadding="0"
  7. <thead> 
  8. <tr> 
  9. <th></th> 
  10. </tr> 
  11. </thead> 
  12. <tbody> 
  13. <tr> 
  14. <td><input class="input" id="fileToUpload" type="file" name="fileToUpload" size="45" /></td> 
  15. </tr> 
  16. <tr> 
  17. <td><button class="button" id="buttonUpload" onclick="return ajaxFileUpload();">Upload</button></td> 
  18. </tr> 
  19. </tbody> 
  20. <tbody> 
  21. <tr> 
  22. <td><span>已上传的附件:</span></td> 
  23. </tr> 
  24. </tbody> 
  25. <tfoot></tfoot> 
  26. </table> 
  27. </form></div> 

在/Lib/Org/目录下放入ThinkPHP文件上传类就可以了,有一些插件我们需要到官方下载。

希望本文所述对大家的PHP程序设计有所帮助。

Tags: AjaxFileUploader

分享到: