ASP .Net Core 中間件的使用(一):搭建靜態文件伺服器/訪問指定文件
- 2020 年 12 月 16 日
- 筆記
前言
隨著Asp .Net Core的升級迭代,很多開發者都逐漸傾向於.net core開發。
.net core是一個跨平台的應用程式,可以在windows、Linux、macOS系統上進行開發和部署,是一個體系結構更精簡模組化框架。
- 生成WebUi和WebApi的統一使用場景;
- 集成新的客戶端框架和開發工作流;
- 前後端分離為兩個dll(view.dll,web.dll),更容易迭代,可以使用應用版本控制;
- 內置依賴注入,更高效安全;
- 高性能模組化的HTTP請求管道;
- 能夠在iis,nginx,apache,docker上進行託管;
- web開發方式更簡化;
釋語
ASP.Net Core接收並處理的大部分是針對靜態文件的請求,最常見的是JavaScript、CSS樣式和圖片。
比較有意思的是,他提供了中間件來處理針對於靜態文件的請求,這種請求可以通過http請求的方式獲取指定的物理文件,並且將其所在的物理目錄結構展示出來。
通過http請求獲取的web資源大部分來源於存儲在伺服器磁碟上的靜態文件。
為什麼使用靜態文件伺服器?因為這樣不需要安裝web伺服器,打開程式即可使用,方便快捷。
詳解
說了這麼多,我們來實際操作一下:
使用的是 StaticFiles 中間件。
我們先創建一個Asp .Net Core Web應用程式,操作方式如下:
1、創建一個名為NetCoreFileServer的項目,選擇web引用程式,相應的中間件會自動載入進來
選擇Web引用程式
發布物理文件
創建項目後,在wwwroot 文件夾下創建一個圖片文件夾,添加一行圖片,然後將程式運行起來,
網址直接導航到圖片://localhost:10610/img/Lighthouse.jpg
默認的話只能訪問wwwroot文件夾下面的文件,如果需要訪問非wwwroot文件下的文件,就需要在中間件中擴展一下;
打開Startup.cs,找到 Configure 方法,在app.UseStaticFiles();後面添加一個擴展方法,如下標紅部分:
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); } app.UseStaticFiles(); app.UseCookiePolicy(); //這是添加的擴張方法 //設置訪問文件 app.UseStaticFiles(new StaticFileOptions { //配置除了默認的wwwroot文件中的靜態文件以外的文件夾提供 Web 根目錄外的文件 , //經過此配置以後,就可以訪問非wwwroot文件下的文件 FileProvider = new PhysicalFileProvider( Path.Combine(Directory.GetCurrentDirectory(), "Image")), RequestPath = "/Image", }); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); }); }
然後訪問一下非wwwroot文件夾下的文件,//localhost:10610/Image/Hydrangeas.jpg
這樣就能正常訪問文件了,其html文件等訪問方式一樣的操作。
靜態文件伺服器
按照類似的方式,我們來做一下靜態文件的訪問;
同理,我們需要在Startup.cs中找到 Configure 方法,在app.UseStaticFiles();後面添加一個擴展方法,如下標紅部分:
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); } app.UseStaticFiles(); app.UseCookiePolicy(); //這是添加的擴張方法 //設置訪問文件 app.UseStaticFiles(new StaticFileOptions { //配置除了默認的wwwroot文件中的靜態文件以外的文件夾提供 Web 根目錄外的文件 , //經過此配置以後,就可以訪問非wwwroot文件下的文件 FileProvider = new PhysicalFileProvider( Path.Combine(Directory.GetCurrentDirectory(), "Image")), RequestPath = "/Image", }); //配置訪問指定文件磁碟 var dir = new DirectoryBrowserOptions(); dir.FileProvider = new PhysicalFileProvider(@"E:\"); app.UseDirectoryBrowser(dir); var staticfile = new StaticFileOptions(); staticfile.FileProvider = new PhysicalFileProvider(@"E:\");//指定目錄 這裡指定E盤,也可以是其它目錄 app.UseStaticFiles(staticfile); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); }); }
配置好後啟動程式進行訪問得到目錄,點擊指定文件即可訪問
這樣我們就能瀏覽指定磁碟的文件了。
你會發現有些文件打開會404,有些又可以打開。那是因為MIME 沒有識別出來。
我們可以手動設置這些 MIME ,也可以給這些未識別的設置一個默認值,如下標紅部分。
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } else { app.UseExceptionHandler("/Home/Error"); } app.UseStaticFiles(); app.UseCookiePolicy(); //這是添加的擴張方法 //設置訪問文件 app.UseStaticFiles(new StaticFileOptions { //配置除了默認的wwwroot文件中的靜態文件以外的文件夾提供 Web 根目錄外的文件 , //經過此配置以後,就可以訪問非wwwroot文件下的文件 FileProvider = new PhysicalFileProvider( Path.Combine(Directory.GetCurrentDirectory(), "Image")), RequestPath = "/Image", }); //配置訪問指定文件磁碟 var dir = new DirectoryBrowserOptions(); dir.FileProvider = new PhysicalFileProvider(@"E:\"); app.UseDirectoryBrowser(dir); var staticfile = new StaticFileOptions(); staticfile.FileProvider = new PhysicalFileProvider(@"E:\");//指定目錄 這裡指定E盤,也可以是其它目錄 staticfile.ServeUnknownFileTypes = true; staticfile.DefaultContentType = "application/x-msdownload"; //設置默認 MIME var provider = new FileExtensionContentTypeProvider(); provider.Mappings.Add(".log", "text/plain");//手動設置對應MIME staticfile.ContentTypeProvider = provider; app.UseStaticFiles(staticfile); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); }); }
設置好以後,對於未識別的,默認為下載。 .log 就被我手動設置成文本方式。
對於前面的這麼多設置,StaticFiles 提供了一種簡便的寫法。UseFileServer
app.UseFileServer(new FileServerOptions() { FileProvider = new PhysicalFileProvider(@"C:\"), EnableDirectoryBrowsing = true });
如果需要加上MIME,StaticFileOptions 需要綁定上。
這樣就弄好一個靜態文件伺服器了,同一個區域網內傳輸文件就可以直接飛速下載。
參考文檔1://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/static-files?view=aspnetcore-2.1&tabs=aspnetcore2x#serve-static-files
參考文檔2://www.cnblogs.com/linezero/p/5541326.html
歡迎關注訂閱我的微信公眾平台【熊澤有話說】,更多好玩易學知識等你來取
作者:熊澤-學習中的苦與樂 公眾號:熊澤有話說 出處: //www.cnblogs.com/xiongze520/p/14143581.html 創作不易,版權歸作者和部落格園共有,轉載或者部分轉載、摘錄,請在文章明顯位置註明作者和原文鏈接。
|