`
wangangie20
  • 浏览: 45452 次
  • 性别: Icon_minigender_2
  • 来自: 厦门
最近访客 更多访客>>
社区版块
存档分类
最新评论

通过Flash实现ASP.NET多文件上传

阅读更多

  关于多文件上传,以前我一直使用JQuery去动态创建文件选择组件,然后POST到服务器去。最近一段时间一直在Flash身边打滚,Flash对于多文件上传有很好的支持,在CodePrject上有一个Flash的多文件上传组件的开源项目,将其封装为ASP.NET控件,当我们在开发ASP.NET程序的时候可以像使用普通控件一样,从工具箱里拉到界面上就可以使用。
  Flash采用Flex开发的,实现了选择文件和统计文件大小的功能,选择了多个文件时会动态的创建Flex组件显示到界面上,并且可以移除所选择的文件。以下是Flex项目结构图:                        
  
  Flex是完全基于事件驱动的开发模型,通过自定义一个Flex的Application来实现文件的多选和文件数量以及上传文件大小的统计等功能。如上图的FileUpload就是自定义的一个组件,扩展自VBox实现了动态创建组件和处理事件。详细参考下面代码:       在Flex的App程序里就使用上面自定义的Application组件来进行设计,详细如下代码块: 
  
  
  .button {fontWeight:normal;}
  
  
  width="400" id="fileContainer">
  width="100%" label="Files to Upload" >
  
  width="100%" visible="false">
  
  
  
  width="275" mode="manual" visible="false" />
  
  
  width="100" styleName="button"/>
  width="100" styleName="button"/>
  width="100" styleName="button"/>
  width="100" styleName="button"/>
  
  
  
  
  完成了多文件选择功能的Flash开发,现在就是想法将其生成的.swf封装到dll成为ASP.NET的服务器端控件,实现这一步很非常简单,将生成的.swf作为资源嵌入到ASP.NET的dll文件里就OK。然后自己定义一个类继承于Control,进行相应方法的重写就达到了目的,这里我们就需要重写Render()方法,在方法里通过调用资源的方法从.dll里读取出嵌入里面的.swf文件资源,然后向客户端输出嵌入flash文件(.swf)的编码就完成了。 
  
  控件中定义了多个属性,方便可视化设置控件的属性值,其中最为主要的属性为:UploadPage,该属性的作用就是指定通过那一个处理程序来处理上传文件的请求,实现请求中上传文件的保存功能。在示例程序里,我自定义了一个HttpHandler来处理上传文件的请求,实现IHttpHandler接口。程序代码如下: namespace FlashUpLoadWeb
  {
  /// 
  /// 上传文件处理程序
  /// 
  public class UploadHandler : IHttpHandler, IRequiresSessionState
  {
  #region IHttpHandler 成员
  public bool IsReusable
  {
  get { return true; }
  }
  public void ProcessRequest(HttpContext context)
  {
  //文件上传存储路径
  string uploadPath = context.Server.MapPath(context.Request.Application Path + "/Upload");
  for (int i = 0; i  0)
  {
  uploadFile.SaveAs(Path.Combine(uploadPath, uploadFile.FileName));
  }
  }
  HttpContext.Current.Response.Write(" ");
  }
  #endregion
  }
  }
  定义好了请求处理程序,这时只需要通过配置文件简单的配置就可以设置控件的处理程序页地址了,如下: 
  
  另外一个属性就是OnUploadComplete,通过它指定当文件上传完毕后调用客户端的那一个JavaScript提交更新页面状态,详细请查看示例代码。最终效果图下图:
  
  
  
  控件还有许多需要完善的地方,比如请求处理程序那一块,上传文件的时候对文件的选择进行判断,不允许重复选择,判断选择队列中的文件在服务器上是否已经存在等等。有兴趣的朋友可以下去改善这些功能!源代码下载
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics