我在较早之前的随笔《基于MVC4+EasyUI的Web开发框架形成之旅--附件上传组件uploadify的使用》Web框架介绍中介绍了基于Uploadify的文件上传操作,免费版本用的是Jquery+Flash实现文件的上传处理,HTML5收费版本的没有试过。随着Flash逐渐退出整个环境,很多浏览器都可能不再支持Flash的了,因此在更新原有EasyUI整个框架的时候,我们对框架全面进行了完善,包括替换了这个Uploadify的文件上传模块,使用EasyUI内置的FileBox控件,结合Jquery的Ajax操作,我们就可以实现了单文件或者多文件的上传操作了。本篇随笔就主要基于这个主题,介绍基于FileBox控件实现文件上传处理,包括前端页面代码和后端的C#处理代码的操作。

1、FileBox控件的使用

FileBox控件原理上是一个TextBox控件和隐藏的一个File控件,因此对于TextBox控件的变化时间onchange依旧可以使用,而由于其隐藏了File控件,那么需要根据DOM规则获取其下面的File控件,从而可以获得文件列表进行Ajax的上传操作,同时由于File文件是一个特殊的内容,我们在上传的时候,使用了JS的FormData对象容器来进行承载文件信息和其他信息,从而能够顺利把文件及其他内容信息一并通过AJax调用,上传到后台去处理。

按照官方的示例,其实就是定义一个HTML元素,并通过脚本方式初始化对应的样式和事件即可,如下所示。

<input class="easyui-filebox" style="width:300px">

//初始化脚本

$('#fb').filebox({

buttonText: '选择文件',

buttonAlign: 'left'

})

这样就可以了。

我们来看看我的实际案例,一般需要上传附件的地方,包括导入Excel文件的记录,或者上传文件作为记录的附件,前者一般是单文件的方式,一次导入一个Excel文件,并加载Excel进行展示,如下所示。

<div  id="tb" style="padding:5px;height:auto"><!-------------------------------搜索框-----------------------------------><fieldset><legend>Excel导入操作</legend><form id="ffSearch" method="post" enctype="multipart/form-data"><div title="Excel导入操作" style="padding: 5px" data-options="iconCls:'icon-key'"><input class="easyui-validatebox" type="hidden" id="AttachGUID" name="AttachGUID" /><br /><input class="easyui-filebox" id="file_upload" style="width:300px" /></div></form><div id="div_files"></div></fieldset><!-------------------------------详细信息展示表格-----------------------------------><table id="grid" title="用户操作" data-options="iconCls:'icon-view'">            </table></div>

和前面Demo的定义类似,这里只是声明了一个FileBox控件,主要还是通过JS代码来进行初始化,和相关的控制。

<script type="text/javascript">$(function () {//添加对话框,上传控件初始化$('#file_upload').filebox({buttonText: '选择文件',  //按钮文本buttonAlign: 'right',   //按钮对齐//multiple: true,       //是否多文件方式//accept: "image/gif,image/bmp,image/jpeg,image/jpg,image/png", //指定文件类型onChange: function (e) {UploadFile(this, "file_upload", "AttachGUID", "div_files");//上传处理}});});</script>

过JS的控制,就可以较好的呈现文件上传的控件了,比不用EasyUI的样式好看很多。

通过onchange的控制,可以对文件操作及时进行响应,如我这里选择文件后,马上进行上传,并进行数据的读取和显示在Datagrid里面。

文件上传的JS逻辑代码如下所示,全部贴出来供参考。

//上传文件操作function UploadFile(_obj, file_ctrlname, guid_ctrlname, div_files) {var value = $("#" + file_ctrlname).filebox('getValue');var files = $("#" + file_ctrlname).next().find('input[type=file]')[0].files;//console.log(files);//传入this参数,也可以用这个获取文件//var files = $(_obj).context.ownerDocument.activeElement.files;//console.log(files);var guid = $("#" + guid_ctrlname).val();if (value && files[0]) {//构建一个FormData存储复杂对象var formData = new FormData();formData.append("folder", '数据导入文件');formData.append("guid", guid);formData.append('Filedata', files[0]);//默认的文件数据名为“Filedata”$.ajax({url: '/FileUpload/Upload', //单文件上传type: 'POST',processData: false,contentType: false,data: formData,success: function (json) {                        //转义JSON为对象var data = $.parseJSON(json);//提示用户Excel格式是否正常,如果正常加载数据ShowUpFiles(guid, div_files);$.ajax({url: '/BillDetail_Cust/CheckExcelColumns?guid=' + guid,type: 'get',dataType:'json',success: function (data) {if (data.Success) {                                InitGrid(); //重新刷新表格数据showTips("文件已上传,数据加载完毕!");}else {showTips("上传的Excel文件检查不通过。请根据页面右上角的Excel模板格式进行数据录入。");}}});          },error: function (xhr, status, error) {$.messager.alert("提示", "操作失败"); //xhr.responseText}});}}

我们这里使用了FormData来存储文件复杂对象。

var formData = new FormData();

通过查询控件的子DOM对象,我们获得File控件对象,并获取控件里面的Files属性。

var files = $("#" + file_ctrlname).next().find('input[type=file]')[0].files;

文件上传后,我们在文件框下面显示已经上传的文件列表,如下代码所示。

ShowUpFiles(guid, div_files);

文件上传到服务器后,我们通过接口获取对应的Excel文件,并转换为JSON列表返回,供页面绑定数据展示。

InitGrid(); //重新刷新表格数据

上传文件展示列表信息,整体界面效果如下所示。

单击删除,弹出确认删除对话框后移除文件即可。

上面通过限定,使用了一个文件,以及可以指定上传文件的格式等,如果我们使用多文件上传,客户端只需要设置Multiple为True即可,后端也不需要调整接口 ,使用同一个接口进行处理即可。

多文件的上传场景,一般是某个记录需要上传文件的情况下,在录入或者编辑界面提供文件上传处理,如下所示。

我们这里可以选择多个文件进行一并上传,初始化fileBox控件的时候,只需要指定multiple为true即可。

//添加对话框,上传控件初始化

$('#file_upload').filebox({

buttonText: '选择文件', //按钮文本

buttonAlign: 'right', //按钮对齐multiple: true,

//accept: "image/gif,image/bmp,image/jpeg,image/jpg,image/png", //指定文件类型

onChange: function (e) {

UploadFile(this, "file_upload", "Attachment_GUID", "div_files");//上传处理 }

});

文件的上传和前面操作类似,只不过,我们这次添加了多个文件。

//构建一个FormData存储复杂对象var formData = new FormData();

formData.append("folder", '政策法规');

formData.append("guid", guid);

for (var i = 0; i < files.length; i++) {

formData.append('Filedata', files[i]);//注意:默认的文件数据名为“Filedata”

}

最后也是统一通过ajax进行条用处理

$.ajax({

url: '/FileUpload/Upload',

type: 'POST',

processData: false,

contentType: false,

data: formData,

success: function (json) {

ShowUpFiles(guid, div_files); //完成后更新已上传的文件列表

showTips("上传完毕!"); //提示完成 },

error: function (xhr, status, error) {

$.messager.alert("提示", "操作失败"); //xhr.responseText }

});

以上就是使用EasyUI的FileBox控件进行处理的前端界面部分。

2、文件上传的后端代码处理

前面小节介绍了控件前端的使用,包括HTML代码的定义和JS的初始化,以及使用AJax异步方式上传文件并展示出来等操作。

文件的上传成功,其实也是需要后端的接口处理,需要对文件进行存储,和数据库信息的更新等操作。

前面我们通过AJax操作,在前端通过JS的方式传输FormData的内容。

$.ajax({

url: '/FileUpload/Upload',

type: 'POST',

processData: false,

contentType: false,

data: formData,

success: function (json) {

//转义JSON为对象//var data = $.parseJSON(json);

ShowUpFiles(guid, div_files); //完成后更新已上传的文件列表

showTips("上传完毕!"); //提示完成 },

error: function (xhr, status, error) {

$.messager.alert("提示", "操作失败"); //xhr.responseText }

});

其中/FileUpload/Upload就是处理的路径地址,我们来看看MVC里面的FileUploadController对应方法Upload即可。

先来看看定义和主要处理文件的部分内容。

我们通过HttpContext.Request.Files 获得多个文件的集合,并进行处理即可。

文件的处理,我们先读取文件内容到对象里面,然后使用了业务类进行统一的存储文件和数据库信息即可。

文件上传成功后,我们返回对应的地址给前端使用(如果需要的话),完整的上传处理文件的后端代码如下所示。

///<summary>/// 多文件上传处理

///</summary>///<param name="guid">附件组GUID</param>///<param name="folder">指定的上传目录</param>///<returns></returns> [AcceptVerbs(HttpVerbs.Post)]

public ActionResult Upload(string guid, string folder)

{

//如果需要修改字段显示,则参考下面代码处理dynamic obj = new ExpandoObject();

List<string> urls = new List<string>();

var result = new CommonResult();

HttpFileCollectionBase files = HttpContext.Request.Files;

if (files != null)

{

int i = 0;

foreach (string key in files.Keys)

{

try

{

#region MyRegion

HttpPostedFileBase fileData = files[i++];

if (fileData != null)

{

HttpContext.Request.ContentEncoding = Encoding.GetEncoding("UTF-8");

HttpContext.Response.ContentEncoding = Encoding.GetEncoding("UTF-8");

HttpContext.Response.Charset = "UTF-8";

string fileName = Path.GetFileName(fileData.FileName); //原始文件名称string fileExtension = Path.GetExtension(fileName); //文件扩展名

FileUploadInfo info = new FileUploadInfo();

info.FileData = ReadFileBytes(fileData);

if (info.FileData != null)

{

info.FileSize = info.FileData.Length;

}

info.Category = folder;

info.FileName = fileName;

info.FileExtend = fileExtension;

info.AttachmentGUID = guid;

info.AddTime = DateTime.Now;

info.Editor = CurrentUser.Name;//登录人

//info.Owner_ID = OwerId;//所属主表记录ID

result = BLLFactory<FileUpload>.Instance.Upload(info);

if (!result.Success)

{

LogTextHelper.Error("上传文件失败:" + result.ErrorMessage);

}

else

{

//返回具体路径地址string serverRealPath = info.BasePath.UriCombine(info.SavePath);

if (!Path.IsPathRooted(info.BasePath) &&

!info.BasePath.StartsWith("http://") &&

!info.BasePath.StartsWith("https://"))

{

//如果是相对目录,加上当前程序的目录才能定位文件地址var url = HttpContext.Request.Url;

var baseurl = url.AbsoluteUri.Replace(url.PathAndQuery, "");

serverRealPath = baseurl.UriCombine(serverRealPath).Replace('\\', '/');

}

urls.Add(serverRealPath);

}

}

#endregion

}

catch (Exception ex)

{

result.ErrorMessage = ex.Message;

LogTextHelper.Error(ex);

}

}

obj.urls = urls;

}

else

{

result.ErrorMessage = "fileData对象为空";

}

var newResult = new { Success = result.Success, ErrorMessage = result.ErrorMessage, urls = urls };

return ToJsonContent(newResult);

}

以上就是使用EasyUI的控件FileBox的前端处理和后端C#代码,从而实现了文件的AJax处理操作,实现较好的体验和功能实现。

完整代码都已全部贴出,方便供参考学习。

在EasyUI项目中使用FileBox控件实现文件上传处理相关推荐

  1. 使用Apache文件上传控件实现文件上传

    本文使用Apache提供的第三方文件上传控件进行文件上传 1.导入第三方commons-fileupload-1.3.2.jar和commons-io-2.5.jar包 2.页面form标签需添加en ...

  2. .Net neatupload上传控件实现文件上传的进度条

    1. 引入bin文件 (可以到neatupload官网下载,也可以到教育厅申报系统中找) 2. 将控件加入到工具栏,在工具栏中点鼠标右键,如图: 3. 加入neatuplaod这个文件夹(可以到nea ...

  3. canvas java 上传截图_在Vue项目中使用html2canvas生成页面截图并上传

    使用方法 项目中引入 npm install html2canvas html代码 //html代码 js代码 // 引入html2canvas import html2canvas from 'ht ...

  4. 根据FileUpload控件名获取上传文件(大小)类型

    /// <summary>     /// 根据FileUpload控件名获取上传文件(大小)类型     /// </summary>     /// <param n ...

  5. iview上传控件upload,手动上传控制

    iview上传控件upload,手动上传控制 场景:实现不通过action地址自动上传,而是通过点击上传按钮手动上传的实现. 效果图: 以下是完整的代码: <template><di ...

  6. 【甄选靶场】Vulnhub百个项目渗透——项目十六:FristiLeaks_1.3(文件上传,py脚本改写,sudo提权,脏牛提权,源码获取)

    Vulnhub百个项目渗透 Vulnhub百个项目渗透--项目十六:FristiLeaks_1.3(文件上传,py脚本改写,sudo提权,脏牛提权,源码获取) 靶场地址

  7. 控件列[Coolite]上传文件

    首先声明,我是一个菜鸟.一下文章中出现技术误导情况盖不负责 1 .配置及单简局布 2.经常用使组件绍介 2.1 Dropdownlist结合TreePanel 2.2 拟模进度条 2.3 上传文件 2 ...

  8. VS2010中使用NeatUpload实现简单的文件上传功能

    neatupload 一个免费的asp.net文件上传组件 项目地址 http://neatupload.codeplex.com/ 首先,从项目网站下载最新版(目前使用的是1.3.26) 在VS20 ...

  9. 基于OkHttp 、Retrofit 、Volley 、RxJava、Novate多种网络框架整合的快速项目开发框架,一行代码实现Ftp文件上传、文件下载、文件删除和进度监听的工具类的使用

    基于OkHttp .Retrofit .Volley .RxJava.Novate多种网络框架整合的快速项目开发框架,Ftp文件上传.文件下载的工具类的使用. 依赖于Ftp的jar包,对上传.下载.删 ...

最新文章

  1. adf盖怎么打开_打印机墨盒怎么更换,看我这篇文章就够了
  2. web.xml中load-on-startup的作用
  3. boost::math模块非有限信号 NaN 环回测试
  4. MATLAB中的微积分运算(数值符号)
  5. MyEclipse取消验证Js的两种方法
  6. 操作系统—进程的定义、组成和组织方式(思维导图)
  7. linux 单网卡 双ip,Linux操作系统单网卡双IP的设置
  8. 什么是servlet?---总结一
  9. 逻辑思维训练500题(修订版)
  10. python处理时间序列非平稳_非平稳时间序列的自相关
  11. zigbee协议栈串口收发 From zigbee菜鸟笔记(十 二)
  12. excel几个数相加等于某个数_EXCEL如何求出哪几个单元格里的数字之和等于某个特定值...
  13. 解决import cv2找不到指定模块问题
  14. 随机展示一个汉字,可以用来让一二年级孩子识字
  15. android 横向头像栏,Android实现个人资料页面头像背景模糊显示包(状态栏)
  16. [ARCGIS]带黑边的IMG格式影像如何消除黑边?
  17. Otterctf 2018 内存取证
  18. 热门表情包+头像+壁纸自动采集多分类微信小程序源码下载支持多种流量主模式
  19. 使用Auto.js实现蚂蚁森林自动收取能量
  20. TextView长按复制实现方法小结

热门文章

  1. 事关企业转型 联想超融合回答的5个关键问题
  2. 代码随想录训练营day50
  3. php新浪微博 登录接口文档,新浪微博的账号登录及PHP api操作
  4. USB总线简介(一)
  5. KUKA入门 示教器初识
  6. kaggle数据调查
  7. 《javascript语言精粹》学习笔记 - 递归函数
  8. 项目管理PMP培训课件(完整版)
  9. 计算机考研845大纲,2017年西北工业大学845电路基础考研大纲
  10. 软件测试用例分享ppt,软件工程测试用例设计ppt