据悉MVC4+EasyUI的Web开发框架形成之旅–附件上传组件uploadify的运用

大体一年前,我还在用Asp.NET开发一些行当管理体系的时候,就已经拔取这几个组件作为文件的上传操作,在小说《Web开发中的文件上传组件uploadify的行使》中能够看来,Asp.NET中如何运用那么些组件进行文件上传的,当时上传文件的拍卖首要也是选择ashx一般处理程序来拓展处理的。本文首要介绍自己的Web开发框架中,在MVC4的环境中怎么着集成那些更加棒的公文上传组件的。

2、上传组件uploadify在Web界面的选用

第一大家要求在HTML代码中放置三个控件,一个是用来上传的控件,一个是用来彰显已上传列表的控件,还有就是添加上传和打消上传的按钮操作,如下所示。

 <tr>
                        <th>
                            <label for="Attachment_GUID">附件上传:</label>
                        </th>
                        <td>                            
                            <div>
                                <input class="easyui-validatebox" type="hidden" id="Attachment_GUID" name="Attachment_GUID" />
                                <input id="file_upload" name="file_upload" type="file" multiple="multiple">
                                <a href="javascript:void(0)" class="easyui-linkbutton" id="btnUpload" data-options="plain:true,iconCls:'icon-save'"
                                    onclick="javascript: $('#file_upload').uploadify('upload', '*')">上传</a>
                                <a href="javascript:void(0)" class="easyui-linkbutton" id="btnCancelUpload" data-options="plain:true,iconCls:'icon-cancel'"
                                    onclick="javascript: $('#file_upload').uploadify('cancel', '*')">取消</a>

                                <div id="fileQueue" class="fileQueue"></div>
                                <div id="div_files"></div>
                                <br />
                            </div>
                        </td>
                    </tr>

界面效果开端化如下所示:

图片 1

理所当然,下一步大家必要丰硕相应的文件上传起首化的操作脚本代码,如下所示。

    <script type="text/javascript">
        $(function () {
            //添加界面的附件管理
            $('#file_upload').uploadify({
                'swf': '/Content/JQueryTools/uploadify/uploadify.swf',  //FLash文件路径
                'buttonText': '浏  览',                                 //按钮文本
                'uploader': '/FileUpload/Upload',                       //处理文件上传Action
                'queueID': 'fileQueue',                        //队列的ID
                'queueSizeLimit': 10,                          //队列最多可上传文件数量,默认为999
                'auto': false,                                 //选择文件后是否自动上传,默认为true
                'multi': true,                                 //是否为多选,默认为true
                'removeCompleted': true,                       //是否完成后移除序列,默认为true
                'fileSizeLimit': '10MB',                       //单个文件大小,0为无限制,可接受KB,MB,GB等单位的字符串值
                'fileTypeDesc': 'Image Files',                 //文件描述
                'fileTypeExts': '*.gif; *.jpg; *.png; *.bmp;*.tif;*.doc;*.xls;*.zip',  //上传的文件后缀过滤器
                'onQueueComplete': function (event, data) {                 //所有队列完成后事件
                    ShowUpFiles($("#Attachment_GUID").val(), "div_files");  //完成后更新已上传的文件列表
                    $.messager.alert("提示", "上传完毕!");                                     //提示完成           
                },
                'onUploadStart' : function(file) {
                    $("#file_upload").uploadify("settings", 'formData', { 'folder': '政策法规', 'guid': $("#Attachment_GUID").val() }); //动态传参数
                },
                'onUploadError': function (event, queueId, fileObj, errorObj) {
                    //alert(errorObj.type + ":" + errorObj.info);
                }
            });

    </script>

在上头的剧本中,均有注释,一看就清楚相关的属性了,不领悟的也可以到官方网站去搜寻明白。值得注意的就是

'uploader': '/FileUpload/Upload'

那行就是付诸文件给MVC的Action进行拍卖,大家在决定器FileUpload的
Upload处理即可。

此外,在附件上传完成后,咱们要求对所在的界面进行更新,以便彰显已上传的列表,那么我们必要充实上边的函数处理即可。

'onQueueComplete': function (event, data) {   

终极证实分外值得注意的地点,就是文本上传的时候,大家需求动态获取界面上的一对要素的值,作为参数传递,那么大家就须求在onUploadStart函数中进行如下处理。

$("#file_upload").uploadify("settings", 'formData', { 'folder': '政策法规', 'guid': $("#Attachment_GUID").val() }); //动态传参数

4、上传组件uploadify在Web开发框架中的界面显得

具体上传组件在的Web开发框架中界面效果如下所示,下图是完全的列表中附件的显示。

图片 2

附件编辑和上传界面如下所示。

图片 3

附件音信查阅效果如下所示:

图片 4

 

本系列小说列表如下:

据悉MVC4+EasyUI的Web开发框架的二种小说:

基于MVC4+EasyUI的Web开发框架形成之旅–总体介绍

按照MVC4+EasyUI的Web开发框架形成之旅–MVC控制器的规划

据悉MVC4+EasyUI的Web开发框架形成之旅–界面控件的使用

基于MVC4+EasyUI的Web开发框架形成之旅–附件上传组件uploadify的施用

依照MVC4+EasyUI的Web开发框架形成之旅–框架总体界面介绍

根据MVC4+EasyUI的Web开发框架形成之旅–基类控制器CRUD的操作

据悉MVC4+EasyUI的Web开发框架形成之旅–权限决定

基于MVC4+EasyUI的Web开发框架经验计算(1)-利用jQuery Tags Input
插件展现采用记录

按照MVC4+EasyUI的Web开发框架经验统计(2)-
使用EasyUI的树控件创设Web界面

根据MVC4+EasyUI的Web开发框架经验总括(3)-
使用Json实体类打造菜单数据

据悉MVC4+EasyUI的Web开发框架经验统计(4)–使用图表控件Highcharts

基于MVC4+EasyUI的Web开发框架经验总括(5)–使用HTML编辑控件CKEditor和CKFinder

根据MVC4+EasyUI的Web开发框架经验统计(6)–在页面中动用下拉列表的处理

依照MVC4+EasyUI的Web开发框架经验统计(7)–达成省份、城市、行政区三者联动

根据MVC4+EasyUI的Web开发框架经验总括(8)–已毕Office文档的预览

据悉MVC4+EasyUI的Web开发框架经验统计(9)–在Datagrid里面完结外键字段的转义操作

基于MVC4+EasyUI的Web开发框架经验计算(10)–在Web界面上贯彻数据的导入和导出

基于MVC4+EasyUI的Web开发框架经验统计(11)–使用Bundles处理简化页面代码

根据MVC4+EasyUI的Web开发框架经验总计(12)–利用Jquery处理数据交互的两种方式

按照MVC4+EasyUI的Web开发框架经验总括(13)–DataGrid控件已毕活动适应宽带中度

根据MVC4+EasyUI的Web开发框架经验统计(14)–自动生成图标样式文件和图标的选项操作

3、上传组件uploadify的C#后台处理代码

在上头的传递参数中,我动用了华语数值,一般情形下,那样会在后台获得中文乱码,所以我们须求在控制器的Action的函数里面安装它的始末格式,如下所示。

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

操纵器FileUpload的后台处理Action代码完整如下所示:

    public class FileUploadController : BaseController
    {
        [AcceptVerbs(HttpVerbs.Post)]
        public ActionResult Upload(HttpPostedFileBase fileData, string guid, string folder)
        {
            if (fileData != null)
            {
                try
                {
                    ControllerContext.HttpContext.Request.ContentEncoding = Encoding.GetEncoding("UTF-8");
                    ControllerContext.HttpContext.Response.ContentEncoding = Encoding.GetEncoding("UTF-8");
                    ControllerContext.HttpContext.Response.Charset = "UTF-8";

                    // 文件上传后的保存路径
                    string filePath = Server.MapPath("~/UploadFiles/");
                    DirectoryUtil.AssertDirExist(filePath);

                    string fileName = Path.GetFileName(fileData.FileName);      //原始文件名称
                    string fileExtension = Path.GetExtension(fileName);         //文件扩展名
                    string saveName = Guid.NewGuid().ToString() + fileExtension; //保存文件名称

                    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

                    CommonResult result = BLLFactory<FileUpload>.Instance.Upload(info);
                    if (!result.Success)
                    {
                        LogTextHelper.Error("上传文件失败:" + result.ErrorMessage);
                    }
                    return Content(result.Success.ToString());
                }
                catch (Exception ex)
                {
                    LogTextHelper.Error(ex);
                    return Content("false");
                }
            }
            else
            {
                return Content("false");
            }
        }

        private byte[] ReadFileBytes(HttpPostedFileBase fileData)
        {
            byte[] data;
            using (Stream inputStream = fileData.InputStream)
            {
                MemoryStream memoryStream = inputStream as MemoryStream;
                if (memoryStream == null)
                {
                    memoryStream = new MemoryStream();
                    inputStream.CopyTo(memoryStream);
                }
                data = memoryStream.ToArray();
            }
            return data;
        }

1、上传组件uploadify的验证及脚本引用

Uploadify 是 JQuery 一个名牌的上传插件,利用 Flash 技术,Uploadify
越过浏览器的限制,控制了总体上传的处理进度,已毕了客户端无刷新的文件上传,那样就兑现了在客户端的上传进程决定,所以,你首先要规定浏览器中早就安装了
Adobe 的 Flash 插件。
Uploadify 当前有多个本子,基于 Flash 是免费的,还有基于 HTML5
的收费版,大家运用免费版,当前版本为v3.2.1。

本条组件需求Jquery库的帮忙,一般景观下,必要添加Jquery的js库,如下所示

<script type="text/javascript" src="~/Scripts/jquery-2.0.3.min.js"></script>

然而由于自己的Web开发框架是基于EasyUI的,一般在网页的初始就会引用相关的类库,已经包含了Jquery的类库了,如下所示。

    @*添加Jquery,EasyUI和easyUI的语言包的JS文件*@
    <script type="text/javascript" src="~/Content/JqueryEasyUI/jquery.min.js"></script>
    <script type="text/javascript" src="~/Content/JqueryEasyUI/jquery.easyui.min.js"></script>
    <script type="text/javascript" src="~/Content/JqueryEasyUI/locale/easyui-lang-zh_CN.js"></script>

之所以大家只须求添加Javascript类库(jquery.uploadify.js),别的添加他的样式文件(uploadify.css)即可:

    @*添加对uploadify控件的支持*@
    @*<script type="text/javascript" src="~/Scripts/jquery-2.0.3.min.js"></script>*@
    <script type="text/javascript" src="~/Content/JQueryTools/uploadify/jquery.uploadify.js"></script>
    <link href="~/Content/JQueryTools/uploadify/uploadify.css" rel="stylesheet" type="text/css" />