日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
深入淺出DotnetCore的項目結(jié)構(gòu)變化

本文轉(zhuǎn)載自微信公眾號「老王Plus」,作者老王Plus的老王 。轉(zhuǎn)載本文請聯(lián)系老王Plus公眾號。

成都創(chuàng)新互聯(lián)主營路北網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app軟件定制開發(fā),路北h5微信小程序定制開發(fā)搭建,路北網(wǎng)站營銷推廣歡迎路北等地區(qū)企業(yè)咨詢

前幾天Review一個項目的代碼,發(fā)現(xiàn)非?;A(chǔ)的內(nèi)容,也會有人理解出錯。

今天,就著這個點,寫一下Dotnet Core的主要類型的項目結(jié)構(gòu),以及之間的轉(zhuǎn)換和演化。

一、最基礎(chǔ)的應(yīng)用Console

控制臺應(yīng)用,是Dotnet Core乃至前邊的Dotnet Framework中,最基礎(chǔ)的項目。

我們來創(chuàng)建一個Console項目看一下:

 
 
 
  1. % dotnet new console -o demo 

創(chuàng)建完成后,打開工程。工程里只有一個文件Program.cs,里面只有一個方法Main:

 
 
 
  1. namespace demo 
  2.     class Program 
  3.     { 
  4.         static void Main(string[] args) 
  5.         { 
  6.             Console.WriteLine("Hello World!"); 
  7.         } 
  8.     } 

在Dotnet Core所有類型的項目中,Program.cs都是最開始的入口,main方法,也是最開始的入口方法。

這個工程中,還有一個文件也需要了解一下,demo.csproj,這是這個項目的定義文件:

 
 
 
  1.  
  2.  
  3.    
  4.     Exe 
  5.     net5.0 
  6.    
  7.  
  8.  

這里面,OutputType告訴編輯器這個工程編譯后可以直接執(zhí)行,TargetFramework定義運行的框架。

注意,這個框架字串有個對照表:net5.0對應(yīng)的是.Net 5.0;如果你想用Dotnet Core 3.1,對應(yīng)的字符串是netcoreapp3.1,而不是net3.1。準確的說,3.1是.Net Core 3.1,而5.0是.Net 5.0。不用太糾結(jié),微軟的命名規(guī)則而已。

這就是控制臺應(yīng)用Console的初始狀態(tài)。

下面,我們看看這個工程如何轉(zhuǎn)變?yōu)閃eb應(yīng)用。

二、轉(zhuǎn)為Web應(yīng)用

第一件事,我們需要改動demo.csproj項目定義文件。

Web應(yīng)用跑在WebHost上面,而不是從直接執(zhí)行。所以,我們需要把OutputType項去掉。

另外,SDK也需要改一下。Console我們用的是Microsoft.NET.Sdk,Web應(yīng)用要改成Microsoft.NET.Sdk.Web:

 
 
 
  1.  
  2.  
  3.    
  4.     net5.0 
  5.    
  6.  
  7.  

改完保存。

這時候,應(yīng)該可以注意到,項目的發(fā)生了變化:

  • 依賴的框架從Microsoft.NETCore.App變成了兩個,多了一個Microsoft.AspNetCore.App,表明現(xiàn)在這是一個Asp.net Core的應(yīng)用;
  • 項目中自動生成了一個目錄Properties,下面多了一個文件launchSettings.json。這個文件大家應(yīng)該很熟悉,就不解釋了。

這時候,應(yīng)用已經(jīng)從Console轉(zhuǎn)為了Web應(yīng)用。

Asp.Net Core框架提供了Host供Web加載。我們需要做的,是把Host構(gòu)建器加到程序中。通常,我們需要兩個構(gòu)建器:

  • 通用主機 Generic host builder
  • Web主機 Web host builder

1. 配置通用主機

通用主機在Microsoft.Extensions.Hosting.Host中,主要給Web應(yīng)用提供以下功能:

  • 依賴注入
  • 日志
  • 配置 IConfiguration
  • IHostedService實現(xiàn)

加入通用主機很簡單,就一個方法CreateDefaultBuilder:

 
 
 
  1. class Program 
  2.     static void Main(string[] args) 
  3.     { 
  4.         Host.CreateDefaultBuilder(args) 
  5.             .Build() 
  6.             .Run(); 
  7.     } 

2. 配置Web主機

Web主機才是真正與Web相關(guān)的內(nèi)容,主要實現(xiàn):

  • Http支持
  • 設(shè)置Kestrol服務(wù)器為Web服務(wù)器
  • 添加IIS支持

加入Web主機,也是一個方法ConfigureWebHostDefaults:

 
 
 
  1. class Program 
  2.     static void Main(string[] args) 
  3.     { 
  4.         Host.CreateDefaultBuilder(args) 
  5.             .ConfigureWebHostDefaults(webBuilder => 
  6.             { 
  7.             }) 
  8.             .Build() 
  9.             .Run(); 
  10.     } 

這個方法用來添加Http請求管道并注入我們需要的服務(wù)。而注入我們需要的服務(wù),就是我們最常見的Startup.cs的內(nèi)容。

下面,我們先創(chuàng)建Startup.cs,

 
 
 
  1. namespace demo 
  2.     public class Startup 
  3.     { 
  4.     } 

在前邊ConfigureWebHostDefaults中,加入Startup,并補齊代碼:

 
 
 
  1. class Program 
  2.     static void Main(string[] args) 
  3.     { 
  4.         Host.CreateDefaultBuilder(args) 
  5.             .ConfigureWebHostDefaults(webBuilder => 
  6.             { 
  7.                 webBuilder.UseStartup(); 
  8.             }) 
  9.             .Build() 
  10.             .Run(); 
  11.     } 

這就是Program.cs中的完整代碼了。整理一下,就是我們常見的樣子:

 
 
 
  1. public class Program 
  2.     public static void Main(string[] args) 
  3.     { 
  4.         CreateHostBuilder(args).Build().Run(); 
  5.     } 
  6.  
  7.     public static IHostBuilder CreateHostBuilder(string[] args) => 
  8.         Host.CreateDefaultBuilder(args) 
  9.             .ConfigureWebHostDefaults(webBuilder => 
  10.             { 
  11.                 webBuilder.UseStartup(); 
  12.             }); 

不過,到這兒還不能正常運行,因為Startup.cs現(xiàn)在還是空的。

3. 補齊Startup類

Startup類在Asp.net Core應(yīng)用中有著重要的作用。這個類用于:

  • 使用DI容器注入服務(wù)
  • 設(shè)置Http Request管道以插入中間件

下面我們補齊所需的方法:

 
 
 
  1. namespace demo 
  2.     public class Startup 
  3.     { 
  4.         public void ConfigureServices(IServiceCollection services) 
  5.         { 
  6.         } 
  7.         public void Configure(IApplicationBuilder app, IWebHostEnvironment env) 
  8.         { 
  9.         } 
  10.     } 

運行,到這兒,Web應(yīng)用已經(jīng)可以正常啟動了。

4. 給應(yīng)用添加路由

Web應(yīng)用啟動了,但里面什么也沒有,是空的。

要訪問Web應(yīng)用中的任何資源,需要配置路由。這兒的路由,基本上就是傳入Http請求與資源之間的映射。

我們可以用下面的中間件來啟動路由:

  • UseRouting
  • UseEndpoints

加一下試試:

 
 
 
  1. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) 
  2.     app.UseRouting(); 
  3.     app.UseEndpoints(endpoint => { 
  4.         endpoint.MapGet("/", async context => 
  5.         { 
  6.             await context.Response.WriteAsync("Hello from Demo"); 
  7.         }); 
  8.     }); 

這次運行,瀏覽器中就看到正確的輸出了。

我們可以用MapGet映射更多資源:

 
 
 
  1. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) 
  2.     app.UseRouting(); 
  3.     app.UseEndpoints(endpoint => 
  4.     { 
  5.         endpoint.MapGet("/", async context => 
  6.         { 
  7.             await context.Response.WriteAsync("Hello from Demo"); 
  8.         }); 
  9.         endpoint.MapGet("/test", async context => 
  10.         { 
  11.             await context.Response.WriteAsync("Hello from Demo.Test"); 
  12.         }); 
  13.         endpoint.MapGet("/about", async context => 
  14.         { 
  15.             await context.Response.WriteAsync("Hello from Demo.About"); 
  16.         }); 
  17.     }); 

到這兒,我們成功地把Console應(yīng)用轉(zhuǎn)為了Web應(yīng)用。

三、延伸內(nèi)容

上面完成的Web應(yīng)用,算是Web應(yīng)用中的基礎(chǔ)?;谶@個內(nèi)容,我們還可以擴展到別的項目結(jié)構(gòu)。

1. 改為MVC應(yīng)用

需要在ConfigureServices中注入AddControllersWithViews,并在Configure中添加MapDefaultControllerRoute:

 
 
 
  1. public class Startup 
  2.     public void ConfigureServices(IServiceCollection services) 
  3.     { 
  4.         services.AddControllersWithViews(); 
  5.     } 
  6.     public void Configure(IApplicationBuilder app, IWebHostEnvironment env) 
  7.     { 
  8.         app.UseRouting(); 
  9.         app.UseEndpoints(endpoint => 
  10.         { 
  11.             endpoint.MapDefaultControllerRoute(); 
  12.         }); 
  13.     } 

2. 改為WebAPI應(yīng)用

需要注入AddControllers和MapControllers:

 
 
 
  1. public class Startup 
  2.     public void ConfigureServices(IServiceCollection services) 
  3.     { 
  4.         services.AddControllers(); 
  5.     } 
  6.     public void Configure(IApplicationBuilder app, IWebHostEnvironment env) 
  7.     { 
  8.         app.UseRouting(); 
  9.         app.UseEndpoints(endpoint => 
  10.         { 
  11.             endpoint.MapControllers(); 
  12.         }); 
  13.     } 

3. 改為Razor應(yīng)用

需要注入AddRazorPages和MapRazorPages:

 
 
 
  1. public class Startup 
  2.     public void ConfigureServices(IServiceCollection services) 
  3.     { 
  4.         services.AddRazorPages(); 
  5.     } 
  6.     public void Configure(IApplicationBuilder app, IWebHostEnvironment env) 
  7.     { 
  8.         app.UseRouting(); 
  9.         app.UseEndpoints(endpoint => 
  10.         { 
  11.             endpoint.MapRazorPages(); 
  12.         }); 
  13.     } 

四、總結(jié)

看下來,其實過程很簡單。通過這種方式,能更進一步理解Dotnet Core的項目結(jié)構(gòu)以及應(yīng)用的運行過程。

希望對大家能有所幫助。

?

本文的配套代碼在:https://github.com/humornif/Demo-Code/tree/master/0038/demo


名稱欄目:深入淺出DotnetCore的項目結(jié)構(gòu)變化
文章URL:http://m.5511xx.com/article/djgiigh.html