对于Uploadify文件上传之前已经讲过一次(文件上传~Uploadify上传控件),只不过没有涉及到多文件的上传,这回主要说一下多个文件的上传,首先,我们要清楚一个概念,多文件上传前端Uploadify是通过轮训的方式去调用我们的后台upload程序的,所以,对于多文件上传来说,也没什么稀奇的.

下面是文件上传后的缩略图如下

ASP.NET多文件上传控件Uploadify的使用方法

列表的组装使用JS模板,这样对于复杂的HTML结构来说,可以减少拼写错误的出现,关闭是将LI元素从UI元素移除,最后提交时,从UI里检查LI元素,然后对它进行组装,并进行发送下面是相关代码

一 HTML模版

<script type="text/html" id="liTemp">
 <li>
  <!--上传后状态-->
  <div class="VedioChange">
  <dl>
   <dt>
   <a href="javascript:;">
    <img width="140" height='92' src="/UploadFiles/2021-04-02/{src}">

二 uploadfiy代码

<script type="text/javascript">
 $(document).ready(function () {
  $("#uploadify").uploadify({
  'uploader': 'js/jquery.uploadify-v2.1.4/uploadify.swf',
  'script': 'UploadHandler.ashx',
  'cancelImg': 'js/jquery.uploadify-v2.1.4/cancel.png',
  'folder': '/UploadFile/',
  'queueID': 'fileQueue',
  'auto': true,
  'multi': true,
  'onComplete': function (event, queueID, fileObj, response, data) {//当单个文件上传完成后触发
   //event:事件对象(the event object)
   //ID:该文件在文件队列中的唯一表示
   //fileObj:选中文件的对象,他包含的属性列表
   //[name] - 已上传文件的名称
   //[filePath] - 已上传文件在服务器上的路径
   //[size] – 文件的大学,单位为字节
   //[creationDate] – 文件的创建日期
   //[modificationDate] – 文件的最后修改日期
   //[type] – 文件的扩展名,以‘.'开始 
   //response:服务器端返回的Response文本,我这里返回的是处理过的文件名称
   //data:文件队列详细信息和文件上传的一般数据
   $("#preview").append(dataTemplate($("#liTemp").text(), { src: response, alt: fileObj.name }));
  },
  'onError': function (event, queueID, fileObj) {//当单个文件上传出错时触发
   alert("文件:" + fileObj.name + " 上传失败!");
  },
  });
 });
 function del(o) {
  $(o).closest("li").remove();
 }
 </script>

三 html代码

<div class="rt">
 <ul class="clearfix w_VedioChange" id="preview">
 </ul>
</div>

<div id="fileQueue"></div>

四 ashx代码

 /// <summary>
 /// Summary description for UploadHandler
 /// </summary>
 public class UploadHandler : IHttpHandler
 {

 public void ProcessRequest(HttpContext context)
 {
  context.Response.ContentType = "text/plain";
  context.Response.Charset = "utf-8";

  HttpPostedFile file = context.Request.Files["Filedata"];
  string uploadPath = HttpContext.Current.Server.MapPath(@context.Request["folder"]);

  if (file != null)
  {
  if (!Directory.Exists(uploadPath))
  {
   Directory.CreateDirectory(uploadPath);
  }

  file.SaveAs(Path.Combine(uploadPath, file.FileName));

  var pathArr = uploadPath.Split('\\');

  context.Response.Write(HttpContext.Current.Request.Url.Scheme
   + "://"
   + HttpContext.Current.Request.Url.Authority
   + "/"
   + pathArr[pathArr.Length - 2]
   + "/"
   + pathArr[pathArr.Length - 1]
   + "/"
   + file.FileName);
  }
  else
  {
  context.Response.Write("0");
  }
 }

 public bool IsReusable
 {
  get
  {
  return false;
  }
 }
 }

为大家推荐一个专题,供大家学习:《ASP.NET文件上传汇总》

本实例只是简单的说明了文件上传的功能,如果在真实项目中使用的话,还需要进一步的进行代码的设计.

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

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。