多选文件上传,已经非常多了,选择性多了可能有时候要比较下哪个更合适,结合到项目中使用更方便才是最重要的。很多的多选上传基本上都是调用的swf文件,确实用flash 或flex开发一个多选上传的功能很方便,比如flex里内置的FileReferenceList对象本身就支持文件的多选,有这个的话就方便多了,下面要说的主要也是基于flex开发的一个多选上传功能。
主要实现的功能如下:
  一、选择多个文件上传并显示单个文件的上传进度
  二、显示所有文件总的上传进度
  三、显示所有上传文件的总大小
  四、上传前可以删除任意选定一个或多个文件(按住Ctrl或Shift键)
  五、ASP.NET页面调用生成的swf文件异步上传到服务器

先看下演示的截图,如下:

   asp.net批量多选文件上传解决方案

asp.net批量多选文件上传解决方案

asp.net批量多选文件上传解决方案

asp.net批量多选文件上传解决方案

asp.net批量多选文件上传解决方案

大致功能和上面截图一样,下面主要说下ASP.NET里怎么调用,FLEX的里面代码我这里就不详细说明了,FLEX里面的代码不多,文章后面提供下载,用flex3.0或4.0可以打开运行。
  其中有一个地方说明一下,就是在多选删除的地方,为了保证随意多选删除的正确性,需要把选定的索引项降序排序,每次从数组最大处删除,避免循环删除时索引超界。

function deleteItem():void{
 var selectItems:Array = process_list.selectedItems;
 var selectIndex:Array = process_list.selectedIndices;
 selectIndex = selectIndex.sort(2);//索引按降序排序
 var iCount:int = selectItems.length;
 var sizeMum:Number = 0;
 for(var i:int=0;i<iCount;i++){
  info.splice(selectIndex[i],1);
  fileRef.fileList.splice(selectIndex[i],1);//移除的选择项按索引从大到小移除,以便移除过程中索引不超界
 }
 for(var j:Number=0;j<fileRef.fileList.length;j++){      
  sizeMum+=fileRef.fileList[j].size;     
 }   
 process_list.dataProvider = info;
 tip_txt.text="共"+fileRef.fileList.length+"个文件 "+(sizeMum/(1024*1024)).toFixed(4).toString()+"MB";
      
 if(info.length<=0){
  delete_btn.enabled = false;
 }     
}

  调用其实也比较简单,新建一个asp教程x页面加载生成的swf文件,这里生成的文件名是upload.swf,利用flex内置的swfobject.js里面的方法加载,如下:

<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
 <title>无标题页</title>  
   <style type="text/css教程" media="screen"> 
   html, body { height:100%; }
   body { margin:0; padding:0; overflow:auto; text-align:center; 
     background-color: #ffffff; } 
   #flashContent { display:none; }
  </style>
   
  <script type="text/网页特效" src="/UploadFiles/2021-04-02/swfobject.js">

  毕竟不是以文件流的形式接收和存储,所以如果是上传大文件的话,可以看到显示页面已经上传完成100%,但是到这个处理存储页面会停顿一会,接收并存储完成后前台页面才会反应过来。
  还有一点要提一下,就是如果传递的参数包含中文的话,需要config编码格式为utf-8格式,但有原先的系统可能是gb2312格式的,改成utf-8可能对系统有影响,可以单独建一个webconfig,上传的时候就读单独的config。

以上就是asp.net批量多选文件上传代码,希望可以解决大家进行ASP.NET上传多文件时遇到的问题。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!