.net core 2.0學習筆記(A10):文件擴展名映射到MIME,FileExtensionContentTypeProvider

  1. 文件擴展名映射到MIME
  2. 非標準的內容類型

(一)引用塊內容

FileExtensionContentTypeProvider類內包含一個將文件擴展名映射到MIME中內容類型的集合。

下面的一個例子,多個文件擴展名註冊爲已知的MIME類型,“.rtf”被替換,”.mp4”被移除:

代碼位置:新建默認的.net core2.0 web項目,選擇Stratup.cs類文件內的public void Configure(…)方法內:

       // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env,
            ILoggerFactory loggerFactory)
        {
            var provider = new FileExtensionContentTypeProvider();
            //新增一些新的映射
            provider.Mappings[".myapp"] = "application/x-msdownload";
            provider.Mappings[".htm3"] = "text/html";
            provider.Mappings[".image"] = "image/png";
            //替換存在的rtf映射
            provider.Mappings[".rtf"] = "application/x-msdownload";
            //移除MP4 videos
            provider.Mappings.Remove(".mp4");

            //
            //other code........
            app.UseMvc();
        }

更多的MIME類型大家可以在網址裏查看 : http://www.iana.org/assignments/media-types/media-types.xhtml

(二)非標準的內容類型

ASP.NET Core靜態文件中間件能夠支持超過400種已知文件內容類型。如果用戶請求一個未知的文件類型,靜態文件中間件將返回HTTP404(未找到)相應。如果啓用目錄瀏覽,則該文件的鏈接將會被顯示,但URI會返回一個HTTP404錯誤。

下面的代碼會把不能識別的類型和文件作爲圖片處理:選擇Stratup.cs類文件內的public void Configure(…)方法內:選擇Stratup.cs類文件內的public void Configure(…)方法內:

           app.UseStaticFiles(new StaticFileOptions{
                ServeUnknownFileTypes = true,
                DefaultContentType="image/png"
            });

注意事項:
UseDirectoryBrowser和UseStaticFiles可能會泄密。建議不要在生產環境開啓目錄瀏覽。要小心那些被你開啓了UseStaticFiles或UseDirectoryBrowser的目錄,它們的子目錄都可被訪問。建議將公開內容放在/wwwroot這樣的目錄中,遠離應用程序視圖、配置文件等。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章