亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ASP.NET MVC 5系列 (五):文件上傳與地址變化處理

2019-11-17 02:03:47
字體:
來源:轉載
供稿:網友

asp.net MVC 5系列 (五):文件上傳與地址變化處理

目錄

文件的上傳和路徑處理必須解決下面列出的實際問題:

1.重復文件處理

2.單獨文件上傳

3.編輯器中文件上傳

4.處理文章中的圖片路徑

5.處理上傳地址的變化

一.上傳文件和重復文件處理

文件處理的原則是:不在數據庫中保存文件,只在數據庫中保存文件信息(Hash值等)。采取文件的md5重命名文件在一般情況足夠處理文件的重復問題,強迫癥傾向則可以考慮將MD5和其他摘要算法結合。

     public static string Save(HttpPostedFileBase file, string path)        {            var root = "~/Upload/" + path + "/";            var phicyPath = HostingEnvironment.MapPath(root);            Directory.CreateDirectory(phicyPath);            var fileName = Md5(file.InputStream) + file.FileName.Substring(file.FileName.LastIndexOf('.'));            file.SaveAs(phicyPath + fileName);            return fileName;        }

二.單獨文件上傳

網站Logo、分類圖標等各種場景需要單獨文件上傳的處理。通過使用UIHintAttribute或自定義繼承自UIHintAttribute的特性我們將文件上傳的前端邏輯的重復代碼消滅,使用統一的視圖文件處理。曾經使用過Uplodify和AjaxFileUploader,前者存在Flash依賴和cookie問題,后者基本已經過時。此處我們采用KindEditor中的文件上傳組件作為演示。非Flash的支持IE6+的方案的核心都是通過iframe方式實現偽AJax上傳,核心還是通過html form post到服務器。

    public class UploadModel    {        [Display(Name = "圖標")]        [UIHint("Upload")]        public string Image { get; set; }        [Display(Name = "簡單模式")]        [UIHint("Editor")]        [AdditionalMetadata("useSimple", true)]        public string Text1 { get; set; }        [Display(Name = "標準模式")]        [UIHint("Editor")]        public string Text2 { get; set; }    }

在我們的實際項目中采取繼承UIHintAttribute的方式,其中的path路徑指定存儲的下級地址,類似的還有DropDownAttribute、EditorAtrribute等等。僅供參考。

    [AttributeUsage(AttributeTargets.PRoperty)]    public class UploadAttribute : UIHintAttribute, IMetadataAware    {        public string Path { get; private set; }        public UploadAttribute(string path = "")            : base("Upload")        {            this.Path = path;        }        public virtual void OnMetadataCreated(ModelMetadata metadata)        {            metadata.AdditionalValues.Add("Path", this.Path);        }    }

Razor:在Shared中添加EditorTemplates文件夾,新建Upload.cshtml文件。

<script>    KindEditor.ready(function (K) {        var editor = K.editor({            allowFileManager: false,            allowImageUpload: true,            formatUploadUrl: false,            uploadJson: '@url',        });        K('#btn_@id').click(function () {            editor.loadPlugin('insertfile', function () {                editor.plugin.fileDialog({                    fileUrl: K('#@id').val(),                    clickFn: function (url, title) {                        K('#@id').val(url);                        $('#image_@id').attr('src', url);                        editor.hideDialog();                    }                });            });        });    });    $('#rest_@id').click(function () {        $('#@id').attr('value', '');        $('#image_@id').attr('src', '@Url.Content("~/Images/default.png")');    });</script>

三.編輯器中的文件上傳

編輯器中的文件上傳和單獨文件上傳的主要區別是上傳后返回值的處理,編輯器需要將url插入到編輯的位置。編輯器采用過CKeditor和UMeditor,兩者都需要我改源代碼才能處理路徑問題。上傳地址和返回值的配置如果不能方便的視圖中調整的編輯器,我個人不認為是好編輯器,這就好比一個類庫沒法擴展和自定義配置一樣。仍然采用KindEditor作為演示。Editor.cshtml的主要內容如下:

<script type="text/javascript">    var editor;    KindEditor.ready(function (K) {        editor = K.create('textarea[name="@Html.IdForModel()"]', {            resizeType: 1,            allowPreviewEmoticons: false,            allowImageUpload: true,            uploadJson: '@UploadManager.UploadUrl',            formatUploadUrl: false,            allowFileManager: false            @if(useSimple)            {                <text>, items: ['fontname', 'fontsize', '|', 'forecolor', 'hilitecolor', 'bold', 'italic', 'underline','removeformat', '|', 'justifyleft', 'justifycenter', 'justifyright', 'insertorderedlist','insertunorderedlist', '|', 'emoticons', 'image', 'link']                </text>            }        });    });</script>

四.處理文章中的圖片路徑

重頭戲來了,這個看似問題可以回避,其實真的無法回避。更換目錄、域名和端口,使用子域名或其他域名作為圖片服務器等等,這些情況讓我們必須處理好這個問題,否則日后會浪費更多的時間。這不是小問題,打開支持插入圖片的各個網站的編輯器,查看一下圖片的路徑,大多是絕對url的,又或者只基于根目錄的。如果你以產品的形式提供給客戶,更不可能要求客戶自己挨個替換文章中的路徑了。

1.在數據庫中不存儲文件路徑,使用URL路徑作為存儲。

2.使用html base元素解決相對路徑的引用問題。

就是base元素,可能有的人認為這個base可有可無,但在處理圖片路徑的問題上,沒有比base更簡潔更優雅的方案了。至少我沒有也沒找到過。其實可以把全部的靜態資源都移除到外部存儲,如果你需要。在測試時,我們切換回使用本地存儲。

@{    var baseUrl = UploadManager.UrlPrefix;}<!DOCTYPE html><html><head>    <meta charset="utf-8" />    <meta name="viewport" content="width=device-width, initial-scale=1.0">    <link href="~/favicon.ico" rel="shortcut icon" type="image/x-icon" />    <title>@ViewBag.Title</title>    <base href="@baseUrl" />        <script src="~/Scripts/jquery-1.11.2.min.js"></script>    @RenderSection("head",false)</head><body>    @RenderBody()</body></html>

五.處理上傳地址的變化

我們需要獨立的圖片服務器處理上傳或者使用第三方的圖片存儲服務時,我們的上傳地址改變了,如果剛剛提到的圖片路徑一樣,因此我們將上傳路徑和圖片路徑都采取配置的方式方便更改,我們就曾經切換到又拍云又切換到自有的服務器。在我的實際使用時配置在數據中使用時采用緩存。為了便于演示我們直接使用配置文件。

首先定義配置文件的處理程序

    public class UploadConfig : IConfigurationSectionHandler    {        public object Create(object parent, object configContext, System.xml.XmlNode section)        {            var config = new UploadConfig();            var urloadUrlNode = section.SelectSingleNode("UploadUrl");            if (urloadUrlNode != null && urloadUrlNode.Attributes != null && urloadUrlNode.Attributes["href"] != null)            {                config.UploadUrl = Convert.ToString(urloadUrlNode.Attributes["href"].Value);            }            var urlPrefixNode = section.SelectSingleNode("UrlPrefix");            if (urlPrefixNode != null && urlPrefixNode.Attributes != null && urlPrefixNode.Attributes["href"] != null)            {                config.UrlPrefix = Convert.ToString(urlPrefixNode.Attributes["href"].Value);            }            return config;        }        public string UploadUrl { get; private set; }        public string UrlPrefix { get; private set; }    }

在web.config中配置

 <configSections>    <section name="UploadConfig" type="SimpleFileManager.UploadConfig, SimpleFileManager" requirePermission="false" />  </configSections>  <UploadConfig>    <UploadUrl href="~/File/Upload/" />    <UrlPrefix href="~/Upload/" /> </UploadConfig>

使用UploadMange緩存和管理配置

    public static class UploadManager    {        private static string uploadUrl;        private static string urlPrefix;        static UploadManager()        {            var config = ConfigurationManager.GetSection("UploadConfig") as UploadConfig;            var url = config != null && !string.IsNullOrEmpty(config.UploadUrl) ? config.UploadUrl : "~/File/Upload";            uploadUrl = url.StartsWith("~") ? UploadHelper.GetUrlFromVisualPath(url) : url;            var prefix = config != null && !string.IsNullOrEmpty(config.UrlPrefix) ? config.UrlPrefix : "~/Upload";            urlPrefix = prefix.StartsWith("~") ? UploadHelper.GetUrlFromVisualPath(prefix) : prefix;        }        public static string UploadUrl        {            get            {                return uploadUrl;            }        }        public static string UrlPrefix        {            get            {                return urlPrefix;            }        }    }

文件Hash的Md5、返回值的Json處理、完整URL的生成和文件的保存這些具體技術的依賴為了便于演示,統一放置在UploadHelper中,因為這些不是重點。實際應用中可以采取接口隔離并通過IoC注入的方式解耦。

點擊此處下載本文的示例代碼


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人h视频在线| 久久久电影免费观看完整版| 欧洲美女7788成人免费视频| 国产精品白嫩初高中害羞小美女| 亚洲欧美成人在线| 久久欧美在线电影| 国内精品久久影院| 国产一区二区三区在线观看视频| 久久av红桃一区二区小说| 成人欧美一区二区三区黑人| 国产视频精品自拍| 欧美高清理论片| 日韩亚洲精品视频| 欧美在线视频免费| 国产精品自拍偷拍| 亚洲人a成www在线影院| 2021久久精品国产99国产精品| 欧美精品18videosex性欧美| 亚洲激情国产精品| 亚洲成人黄色网| 久久久免费观看| 久久在精品线影院精品国产| 国产精品视频一区二区高潮| 91精品国产91久久久久久最新| 在线视频日本亚洲性| 91精品国产91久久| 久久久国产成人精品| 在线视频欧美日韩| 亚洲第一区中文字幕| 久久国产精品电影| 国产精品成人一区二区| 亚洲一区二区日本| 亚洲精品动漫100p| 91精品综合久久久久久五月天| 日韩一区二区三区xxxx| 欧美国产第二页| 91久久综合亚洲鲁鲁五月天| 国产在线精品成人一区二区三区| 操人视频在线观看欧美| 国产一区二区三区高清在线观看| 欧美一级大片视频| 成人国产精品久久久久久亚洲| 不卡中文字幕av| 欧美日本精品在线| 国产精品久久电影观看| 国产视频精品xxxx| 成人精品一区二区三区电影免费| 日韩有码在线视频| 欧美日韩国产影院| 一区二区三区精品99久久| 日韩成人在线视频| 欧美午夜视频在线观看| 日韩av男人的天堂| 亚洲综合视频1区| 欧美国产精品人人做人人爱| 国产精品九九久久久久久久| 精品一区二区亚洲| 国产精品免费观看在线| 最近2019年中文视频免费在线观看| 国产精品久久久久久久久久小说| 国产精品久久久久久久美男| 国产一区二区三区丝袜| 色综合伊人色综合网站| 亚洲黄在线观看| 国产亚洲精品va在线观看| 国产精品久久久久久久久久东京| 成人黄色在线观看| 91午夜理伦私人影院| yellow中文字幕久久| 午夜精品久久久99热福利| 中文字幕精品—区二区| 91精品视频在线看| 国产区精品在线观看| 亚洲第一免费播放区| 国产精品视频色| 国产精品黄色影片导航在线观看| 日韩精品在线私人| 亚洲跨种族黑人xxx| 欧美精品久久久久久久免费观看| 亚洲韩国欧洲国产日产av| 国产精品免费一区豆花| 国产精品美女网站| 亚洲欧美日韩国产中文| 伊人久久综合97精品| 精品亚洲va在线va天堂资源站| 亚洲人午夜精品| 亚洲精品99久久久久中文字幕| 亚洲视频电影图片偷拍一区| 人体精品一二三区| 岛国视频午夜一区免费在线观看| 国产欧美亚洲视频| 国产日韩视频在线观看| 尤物九九久久国产精品的特点| 宅男66日本亚洲欧美视频| 久久久国产精品视频| 欧美一级视频在线观看| 国产精品女视频| 欧美最猛性xxxxx免费| 欧美大片欧美激情性色a∨久久| 黑人巨大精品欧美一区二区三区| 亚洲一区二区三区777| 欧美激情一区二区久久久| 91久热免费在线视频| 欧美在线免费视频| 亚洲精品在线不卡| 日韩欧美一区二区三区久久| 精品亚洲一区二区三区| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲欧美日韩久久久久久| 日韩中文视频免费在线观看| 81精品国产乱码久久久久久| 欧美久久精品一级黑人c片| 久久777国产线看观看精品| 亚洲天堂视频在线观看| 欧美日韩成人在线观看| 久久国产精品99国产精| 中文欧美在线视频| 国产精品欧美日韩一区二区| 久久在线观看视频| 亚洲在线观看视频| 亚洲欧美日韩高清| 亚洲国内精品在线| www日韩中文字幕在线看| 亚洲四色影视在线观看| 国产精品日韩在线一区| 在线播放国产精品| 欧美精品第一页在线播放| 日本欧美一二三区| 成人精品视频久久久久| 欧美猛交免费看| 成人免费大片黄在线播放| 海角国产乱辈乱精品视频| 国产精品视频中文字幕91| 热re99久久精品国产66热| 77777少妇光屁股久久一区| 91经典在线视频| 国产亚洲欧美另类中文| 亚洲免费中文字幕| 国产欧美精品在线| 亚洲色图欧美制服丝袜另类第一页| 国产中文字幕亚洲| 精品久久中文字幕| 成人精品视频在线| 色婷婷久久av| 久久91亚洲精品中文字幕| 亚洲欧美国产精品va在线观看| 国产精自产拍久久久久久蜜| 福利视频第一区| 国产亚洲精品美女久久久| 色狠狠av一区二区三区香蕉蜜桃| 中文字幕在线成人| 国产精品亚发布| 日韩成人av在线播放| 色婷婷亚洲mv天堂mv在影片| 国产精品免费小视频| 欧美第一黄网免费网站| 成人黄色生活片| 亚洲性生活视频| 亚洲欧美国产日韩中文字幕| 国产亚洲欧洲高清一区| 色偷偷偷综合中文字幕;dd| 亚洲国模精品一区| 北条麻妃一区二区三区中文字幕| 亚洲免费伊人电影在线观看av|