分享

flash+fileupload 上传文件 - Flash - JavaEye论坛

 欢欢2008 2010-12-07

表单页面代码:

1.嵌入JS文件

Html代码 复制代码
  1. <script src="formhelper_fileMem.js" language="JavaScript"></script>  

 formhelper_fileMem.js

Js代码 复制代码
  1. function $_(id){   
  2.     return document.getElementById(id);   
  3. }   
  4.   
  5. //Flash的初始化事件,当Flash在浏览器已完全载入后将自动调用此脚本方法(如果存在的话)。   
  6. //在此事件中可进行相应的初始化工作,比如设置上传文件的地址、允许上传的文件类型等。   
  7. function FileUploader_onInit(){   
  8.     var o = $_('FileUploader');   
  9.     o.setUploadFileType("图片文件(*.jpg,*.bmp,*.doc)|*.jpg;*.bmp;*.doc");   
  10.     o.setUploadFileUrl("http://localhost:7001/formhelper/upload.jsp");   
  11.     o.setMaxFileSize(-1);   
  12. }   
  13.   
  14.   
  15. //当Flash出现错误时(如上传文件)将触发此事件   
  16. function FileUploader_onError(error){   
  17.     alert("出现错误,错误信息为:" + error);   
  18.     var o = $_('FileUploader');   
  19.     o.resetUpload();   
  20. }   
  21.   
  22. //当正在上传文件数据时将触发此事件,通过此事件中的两个参数可计算得知当前的上传进度。   
  23. //total : 返回的是当前正在上传文件的总大小,单位是:字节   
  24. //size  : 返回的是共已上传到服务器的文件数据大小,单位是:字节   
  25. function FileUploader_onUploading(total,size){   
  26.     var o = $_('per');   
  27.     o.style.width = (size / total * 500) + "px";   
  28.     o.innerText = Math.round((size / total * 100),2) + "%";   
  29. }   
  30.   
  31. //当Flash已将所有文件数据上传到服务端时(服务端不一定已接收完数据)将触发此事件。   
  32. //file : 已上传的文件对象,拥有两个属性   
  33. //file.name : 文件名(不带任何路径)   
  34. //file.size   : 文件大小,单位:字节   
  35. function FileUploader_onSendComplete(file){   
  36.     alert("客户端已发送完文件的数据,文件名" + file.name + ",大小:" + file.size);   
  37. }   
  38.   
  39. //当Flash已上传完数据并服务器已接收完数据时将触发此事件。   
  40. function FileUploader_onUploadComplete(data){   
  41.     alert("上传文件完成,服务器返回数据:" + data);       
  42.     $_('FileUploader').resetUpload();   
  43. }   

2.表单嵌入的FLASH控件

Html代码 复制代码
  1. <tr>  
  2. <td>  
  3.       <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"  
  4.             id="FileUploader" width="100%" height="80"  
  5.             codebase="http://fpdownload.macromedia.com/get/flashplayer/current/swflash.cab">  
  6.             <param name="movie" value="FileUploader.swf" />  
  7.             <param name="quality" value="high" />  
  8.             <param name="bgcolor" value="#ffffff" />  
  9.             <param name="allowScriptAccess" value="sameDomain" />  
  10.             <embed src="FileUploader.swf" quality="high" bgcolor="#ffffff"  
  11.                 width="100%" height="100%" name="FileUploader" align="middle"  
  12.                 play="true"  
  13.                 loop="false"  
  14.                 quality="high"  
  15.                 allowScriptAccess="sameDomain"  
  16.                 type="application/x-shockwave-flash"  
  17.                 pluginspage="http://www.adobe.com/go/getflashplayer">  
  18.             </embed>  
  19.     </object>  
  20. </td>  
  21. </tr>  

 3.对象的方法

Html代码 复制代码
  1. 附:对象方法   
  2.   
  3. 1)setUploadFileUrl(url)   
  4.   
  5. 设置接收上传文件数据的地址。   
  6.   
  7. url : 路径地址。   
  8.   
  9. 2) setUploadFileType(exts)   
  10.   
  11. 设置允许选择的文件类型。   
  12.   
  13. exts: 文件类型列表,格式为“描述|类型列表(使用“;”号隔开)”,如果需要设置多种类型可连续设置。如:   
  14.   
  15. "文本文件(*.txt)|*.txt|图片文件(*.jpg,*.bmp,*.png)|*.jpg;*.bmp;*.png|所有文件(*.*)|*.*"   
  16.   
  17. 3)  setMaxFileSize(size)   
  18.   
  19. 设置最大允许上传的文件大小,单位是"字节",如果设置为"-1"则表示不限制大小!如果选择的文件已超出此值,将自动触发onError事件,并返回"文件大小已超出限制范围"错误信息.   
  20.   
  21. 4)setBgColor(color)   
  22.   
  23. 设置Flash的背景颜色。   
  24.   
  25. color : 可接受已知颜色的名称或以#开头的16进制颜色值   
  26.   
  27. 5)setButtonColor(color)   
  28.   
  29. 设置上传按钮的背景颜色。   
  30.   
  31. color : 可接受已知颜色的名称或以#开头的16进制颜色值   
  32.   
  33. 6)setButtonText(text)   
  34.   
  35. 设置上传按钮的文本,上传按钮的文本默认为“上传本地文件”。   
  36.   
  37. text : 字符串   
  38.   
  39. 7)setProgressBarColor(color)   
  40.   
  41. 设置上传进度条的颜色。   
  42.   
  43. color : 可接受已知颜色的名称或以#开头的16进制颜色值   
  44.   
  45. 8)setProgressBarBgColor(color)   
  46.   
  47. 设置上传进度条的背景颜色。   
  48.   
  49. color : 可接受已知颜色的名称或以#开头的16进制颜色值   
  50.   
  51. 9)selectLocalFile()   
  52.   
  53. 弹出选择文件窗口,并确定选择文件后自动将文件上传到服务器!此方法可代替Flash中上传按钮的点击。   
  54.   
  55. 10)resetUpload()   
  56.   
  57. 重设置Flash的上传界面,当Flash上传文件后默认的上传按钮已被隐藏,显示的则是一条上传进度条。  

 4.upload.jsp

Java代码 复制代码
  1. <%@ page  import="org.apache.commons.fileupload.*"%>   
  2. <%@ page  import="java.text.SimpleDateFormat"%>   
  3. <%@ page  import="java.util.*"%>   
  4. <%@ page  import="java.io.*"%>   
  5. <%      
  6.   String temp=request.getRealPath("/")+"\\files\\";   //临时目录    
  7.   String loadpath=request.getRealPath("/")+"\\files\\"//上传文件存放目录   
  8. request.setCharacterEncoding("utf-8");   
  9.     DiskFileUpload fu = new DiskFileUpload();    
  10.     fu.setSizeMax(1*1024*1024); // 设置允许用户上传文件大小,单位:字节    
  11.     fu.setSizeThreshold(40);   // 设置最多只允许在内存中存储的数据,单位:字节    
  12.     fu.setRepositoryPath(temp); // 设置一旦文件大小超过getSizeThreshold()的值时数据存放在硬盘的目录    
  13.     List fileItems = fu.parseRequest(request);    
  14.     Iterator iter = fileItems.iterator(); // 依次处理每个上传的文件    
  15.     while (iter.hasNext()) {    
  16.         FileItem item = (FileItem) iter.next();// 忽略其他不是文件域的所有表单信息    
  17.         if (!item.isFormField()) {    
  18.          String name = item.getName();//获取上传文件名,包括路径    
  19.          name=name.substring(name.lastIndexOf("\\")+1);//从全路径中提取文件名        
  20.          long size = item.getSize();    
  21.          if((name==null||name.equals("")) && size==0)    
  22.          continue;    
  23.          SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");   
  24.          String newName=sdf.format(new Date());   
  25.          File fNew= new File(loadpath, newName+name);            
  26.          item.write(fNew);     
  27.       String trance = "/files/"+newName+name;   
  28.       String returnStr="<tr id='"+newName+"'><td class='style6'><a href='"+trance+"' target='_blank'>"+name+"</a></td><td class='style6'>"+fileType+"</td><td class='style6'><a href='#'><img src='/commons/menu/del.gif' border='0'></a></td></tr>";   
  29.       response.setContentType("text/html;charset=utf-8");   
  30.       out.println(returnStr); //返回给 onUploadComplete   
  31.     }    
  32.  }    
  33.   
  34. %>     
 

注:该flash下载地址 http://www./xwzj/ps/flash/200810/2097.html

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多