.Net 6簡介並和之前版本寫法做對比
阿新 • • 發佈:2021-12-25
目錄
- 介紹
- 正文
- 對比
- 向DI 容器新增服務
- 日誌記錄
- Serilog 整合
- 完成的來看效果
介紹
vs2022正式版已經推出了,估計很多人已經下載並開始建立.Net 6 開始嚐鮮了,本節我簡要的給大家介紹一下.Net 6的一些改動。
正文
本次.Net6帶來最明顯的變化就是:
- 採用頂級語句,我們看不到
Program.Main()
了。 - 隱式 using 指令,隱式 using 指令意味著編譯器會根據專案型別自動新增一組 using 指令。
- 移除了Startup檔案。
var builder = WebApplication.CreateBuilder(args); var app = builder.Build(); app.Run();
對於這樣的改動大家可能會覺得這是C# 10 帶來的優化,但我的理解是.Net6為了新手更加方便入門,早期我們使用.Net Core 2/3/5 版本,還要給新人解釋系統啟動入口Program.Main()
以後不需要了,配置拆分成兩個檔案Program.cs和Startup.cs雖然做到了關注點分離,但是對於新人會難以理解這次也沒了,當我們討論Startup的時候不用在去解釋如何呼叫的2個約定方法,即使它們沒有顯式實現介面,也可以呼叫它們。
我們來看一下之前的語法,我們有一大堆巢狀的 lambda,程式碼看上去非常複雜。
var hostBuilder = Host.CreateDefaultBuilder(args).ConfigutiDKpMxGyreServices(services => { services.AddControllers(); }) .ConfigureWebHostDefaults(webBuilder => { webBuilder.Configure((ctx,app) => { if (ctx.HostingEnvironment.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.UseStaticFiles(); app.UseRouting(); app.UseEndpoints(endpoints => { endpoints.MapGet("/",() => "Hello World!"); endpoints.MapRazorPages(); }); }); }); hostBuilder.Build().Run();
升級到.Net 6之後,我們可以使用更簡單的 API 來實現。
var builder = WebApplication.CreateBuilder(args); builder.Services.AddControllers(); var app = builder.Build(); app.MapGet("/",() => "Hello World!"); app.Run();
對比
我們將 2個版本的語法對比來看
向DI 容器新增服務
var hostBuilder = Host.CreateDefaultBuilder(args); hostBuilder.ConfigureServices(services => { services.AddControllers(); services.AddSingleton<MyThingy>(); }) var builder = WebApplication.CreateBuilder(args); builder.Services.AddControllers(); builder.Services.AddSingleton<MyThingy>();
日誌記錄
var hostBuilder = Host.CreateDefaultBuilder(args); hostBuilder.ConfigureLogging(builder => { builder.AddFile(); }) var builder = WebApplication.CreateBuilder(args); builder.Logging.AddFile();
Serilog 整合
public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .UseSerilog() // <-- Add this line .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); }); builder.Host.UseSerilog();
完成的來看效果
public interface IHelloService { string Hello(bool isHappy); } public class HelloService : IHelloService { public string Hello(bool isHappy) { var hello = $"Hello World"; if (isHappy) return $"{hello},you seem to be happy today"; return hello; } } using MinimalApiDemo; using System.Security.Claims; var builder = WebApplicationwww.cppcns.com.CreateBuilder(args); builder.Services.AddScoped<IHelloService,HelloService>(); // Add services to the container. builder.Services.www.cppcns.comAddControllers(); // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle builder.Services.AddEndpointsApiExplorer(); builder.Services.AddSwaggerGen(); var app = builder.Build(); // Configure the HTTP request pipeline. if (app.Environment.IsDevelopment()) { app.UseSwagger(); app.UseSwaggerUI(); } app.UseHttpsRedirection(); app.UseAuthorization(); app.MapControllers(); app.MapGet("/Hello",(bool? isHappy,IHelloService service) => { if (isHappy is null) return Results.BadRequest("Please tell if you are happy or not :-)"); return Results.Ok(service.Hello((bool)isHappy)); }); app.Run();
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。