基于MVC+EasyUI的Web開發框架形成之旅--附件上傳組件uploadify的使用

當我還在用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庫,如下所示

<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" />

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>

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



當然,下一步我們需要添加相應的文件上傳初始化的操作腳本代碼,如下所示。

<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() 
}); //動態傳參數

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

4、上傳組件uploadify在Web開發框架中的界面展示

具體上傳組件在的Web開發框架中界面效果如下所示,下圖是總體的列表中附件的展示。



附件編輯和上傳界面如下所示。



附件信息查看效果如下所示:
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,345評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,494評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,283評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,953評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,714評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,410評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,940評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,776評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,210評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,642評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,878評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,654評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,958評論 2 373

推薦閱讀更多精彩內容