博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MVC文件上传04-使用客户端jQuery-File-Upload插件和服务端Backload组件实现多文件异步上传...
阅读量:6941 次
发布时间:2019-06-27

本文共 4835 字,大约阅读时间需要 16 分钟。

本篇使用客户端jQuery-File-Upload插件和服务端Badkload组件实现多文件异步上传。MVC文件上传相关兄弟篇:

 

 

  

 

  处理文件上传的服务端组件Backload

用于处理文件上传的服务端组件。Backload与客户端文件上传插件(比如jQuery-File-Upload)配合使用,初步形成一个处理文件异步上传的解决方案。

□ Badkload的一些功能和特点

● 零配置:Backload提供默认BackloadDemoController用来处理上传文件请求。如果其它控制器也想拥有"Backload处理上传文件的超强能力",只需要继承BackloadDemoController就可以。

● 在web.config中显式配置
● 支持多种存储位置:文件夹、数据库(通过Entity Framework)、云存储(将来支持)
● 根据不同的请求上下文把上传文件保存到不同的位置
● 根据上传文件的不同类型保存到不同的位置
● 支持对图片的裁剪,而参数可以在web.confgig中配置
● 支持对多个图片的处理
● 支持图片类型转换
● 支持生成缩略图
● 支持在服务端创建唯一的文件名(GUIDs)
● 还可以在原始文件和修改文件之间建立映射,并返回给客户端一个友好的名称。
● 良好的可扩展性:通过实现Badkload的接口和使用ExportAttribute特性。
● 安全性:为控制器加上验证和授权
● 可调试:方便断点调试发现错误
...

 

□ 安装客户端jQuery-File-Upload插件和服务端Badkload组件,有2种方式:

1、分别安装客户端和服务端所需的插件和组件

● 安装服务端的Backload:

PM> Install-Package Backload

● 如果客户端选择使用jQuery-File-Upload插件,通过如下来安装这个客户端文件上传插件:

PM> Install-Package JQuery_File_Upload_Plugin

 

2、安装Query-File-Upload结合Backload实现文件上传的Demo,一次性安装客户端和服务端所需的插件和组件:

PM> Install-Package JQueryFileUpload_Demo_with_Backload

 

  例子:零配置实现多文件上传

□ 新建一个MVC4项目,工具--库程序包管理器--程序包管理器控制台,输入:

PM> Install-Package JQueryFileUpload_Demo_with_Backload

 

引用文件夹多了如下文件:

 

App_Start文件夹里多了如下BackloadConfig.cs文件,里面有jQuery File Upload插件所有需要的js和css文件:

 

Content文件夹多了如下文件:

 

Controller文件夹多了一个控制器:

 

Scripts文件夹多了如下文件:

 

Views文件夹多了如下文件夹和文件:

 

□ 运行http://localhost:1631/BackloadDemo/Index,发现如下问题:

1、工具--库程序包管理器--程序包管理器控制台,被禁用

关闭VS,重新打开就恢复。

 

2、报错

未能加载文件或程序集“WebGrease, Version=1.5.1.25624, Culture=neutral, PublicKeyToken=31bf3856ad364e35”或它的某一个依赖项。找到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)

 

通过"uninstall-package -f WebGrease"先卸载,然后通过"install-package WebGrease"再下载最新版本,问题解决。

 

□ 再次运行

 

□ 添加2个上传文件,出现上传文件列表并配有缩略图

 

□ 分别点击"Start"按钮,上传成功后,"Start"按钮消失,出现"Delete"按钮。

 

□ 根目录下多了Files文件夹

 

□ File文件夹下不仅有上传的图片,还有一个存放缩略图的文件夹_thumbs:

 

□ 勾选上传文件列表中的一行,点击"Delete":

界面少了一行记录:

 

File文件夹下原先的图片也被删除:

 

  总结

 

● 仅仅通过PM> Install-Package JQueryFileUpload_Demo_with_Backload 安装了客户端文件上传插件jQuery-File-Upload和服务端文件处理组件Backload,没有做任何配置,就可以进行多个文件的上传。

● 文件默认被上传到根目录下的Files文件夹,需要这个文件夹的"写"权限。

 

□ BackloadDemoController是默认的控制器

1:  using System.Web.Mvc;
2:   
3:  namespace MvcApplication6.Controllers
4:  {
5:      public class BackloadDemoController : Controller
6:      {
7:          //
8:          // GET: /BackupDemo/
9:          public ActionResult Index()
10:          {
11:              return View();
12:          }
13:      }
14:  }

 

□ BackloadDemoController是默认的上传文件视图

展开@{    Layout = null;}    
JQuery File Upload Plugin with Backload demo installation @Styles.Render("~/Content/themes/base/css") @Styles.Render("~/Content/css")
@Styles.Render("~/bundles/fileupload/bootstrap/BasicPlusUI/css")
Add files...
 
@Scripts.Render("~/bundles/jquery") @Scripts.Render("~/bundles/jqueryui")
@Scripts.Render("~/bundles/fileupload/bootstrap/BasicPlusUI/js")

 

以上,html部分:

● <form id="fileupload" action="/Backload/UploadHandler" method="POST" enctype="multipart/form-data">放置添加、取消、上传等按钮
● <script id="template-upload" type="text/x-tmpl">上传文件列表
● 下载文件列表

 

css部分:

● @Styles.Render("~/Content/themes/base/css")
● @Styles.Render("~/Content/css")
● @Styles.Render("~/bundles/fileupload/bootstrap/BasicPlusUI/css") 使用Backloads的bundeling功能注册jQuery File Upload所需的css

 

js部分:

● @Scripts.Render("~/bundles/jquery")
● @Scripts.Render("~/bundles/jqueryui")
● @Scripts.Render("~/bundles/fileupload/bootstrap/BasicPlusUI/js") 使用Backloads的bundeling功能注册jQuery File Upload所需的js
● script src="~/Scripts/FileUpload/backload.demo.js"></script> 初始化jQuery File Upload

参考资料:
※ Backload官网
※ Backload例子
※ nuget上的Backload

※ jQuery File Upload官网

※   github上的jQuery File Upload介绍
※   github上的jQuery File Upload源码

※   下载jQuery File Upload结合Backload的MVC案例

你可能感兴趣的文章
配置ODBC连接SQL Server
查看>>
创建mysqlEvent
查看>>
莫言如是说
查看>>
Docker-compose一键部署gitlab中文版
查看>>
Eclipse与MyEclipse在发布web项目时的区别
查看>>
设置证书登录Centos7
查看>>
python网络爬虫(一)准备工作
查看>>
2018-07-26期 MapReduce求部门工资总和及平均工资
查看>>
Exchange2010-13-16 使用数据库可移植性恢复数据库
查看>>
我的友情链接
查看>>
Linux学习之CentOS(三十三)--DNS基础及域名系统架构
查看>>
Starcraft2是非常优秀的hardcore游戏
查看>>
压力测试工具之JMeter
查看>>
我的友情链接
查看>>
[问题解决]搭建LAMP服务器环境流程
查看>>
系统管理中的三大利刃
查看>>
多对多查询一对一SQL
查看>>
prinf 导致死机 指针和×××的强制转换
查看>>
我的友情链接
查看>>
S5PV210--1---210启动方式和代码前16字节
查看>>