基于MVC+EasyUI的Web开发框架形成之旅–附件上传组件uploadify的使用
admin
2023-08-02 16:06:30
0

当我还在用Asp.NET开发一些行业管理系统的时候,就曾经使用这个组件作为文件的上传操作,在随笔《Web开发中的文件上传组件uploadify的使用》中可以看到,Asp.NET中如何使用这个组件进行文件上传的,当时上传文件的处理主要也是使用ashx一般处理程序来进行处理的。本文主要介绍我的Web开发框架中,在MVC的环境中如何集成这个非常棒的文件上传组件的。

1、上传组件uploadify的说明及脚本引用

Uploadify 是 JQuery 一个著名的上传插件,利用 Flash 技术,Uploadify 越过浏览器的限制,控制了整个上传的处理过程,实现了客户端无刷新的文件上传,这样就实现了在客户端的上传进度控制,所以,你首先要确定浏览器中已经安装了 Adobe 的 Flash 插件。Uploadify 当前有两个版本,基于 Flash 是免费的,还有基于 HTML5 的收费版,我们使用免费版,当前版本为v3.2.1。
这个组件需要Jquery库的支持,一般情况下,需要添加Jquery的js库,如下所示

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

@*添加Jquery,EasyUI和easyUI的语言包的JS文件*@


所以我们只需要添加Javascript类库(jquery.uploadify.js),另外加上他的样式文件(uploadify.css)即可:

@*添加对uploadify控件的支持*@
@**@

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

首先我们需要在HTML代码中放置两个控件,一个是用来上传的控件,一个是用来显示已上传列表的控件,还有就是添加上传和取消上传的按钮操作,如下所示。

 
    
        
    
                                
        
    

界面效果初始化如下所示:

当然,下一步我们需要添加相应的文件上传初始化的操作脚本代码,如下所示。

在上面的脚本中,均有注释,一看就明白相关的属性了,不明白的也可以到官方网站去查找了解。值得注意的就是

\'uploader\': \'/FileUpload/Upload\'

这行就是提交文件给MVC的Action进行处理,我们在控制器FileUpload的 Upload处理即可。
另外,在附件上传完毕后,我们需要对所在的界面进行更新,以便显示已上传的列表,那么我们需要增加下面的函数处理即可。

\'onQueueComplete\': function (event, data) {

最后说明非常值得注意的地方,就是文件上传的时候,我们需要动态获取界面上的一些元素的值,作为参数传递,那么我们就需要在onUploadStart函数中进行如下处理。

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

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.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;
    }

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

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

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

附件信息查看效果如下所示:

相关内容

热门资讯

Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
Apache Doris 2.... 亲爱的社区小伙伴们,我们很高兴地向大家宣布,Apache Doris 2.0.0 版本已于...
python清除字符串里非数字... 本文实例讲述了python清除字符串里非数字字符的方法。分享给大家供大家参考。具体如下: impor...