.Net 6相比之前版本有哪些长尾词写法上的改变?

2026-04-01 10:111阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计960个文字,预计阅读时间需要4分钟。

.Net 6相比之前版本有哪些长尾词写法上的改变?

目录介绍正文对比向DI添加服务日志记录Serilog集成完成的来查看效果介绍vs2022正式版已推出,预计很多人已下载并开始创建.Net 6项目,本节简要介绍。

正文本节将简要介绍如何使用Serilog进行日志记录,并集成到.Net 6项目中。

对比对比其他日志库,Serilog提供了更多灵活性和可扩展性。

向DI添加服务在Startup.cs中,可以通过以下方式添加Serilog服务到DI容器:

csharppublic void ConfigureServices(IServiceCollection services){ services.AddLogging(loggingBuilder=> { loggingBuilder.ClearProviders(); loggingBuilder.AddSerilog(); });}

日志记录使用Serilog进行日志记录非常简单,如下所示:

csharppublic void LogInformation(){ Log.Information(This is an informational message.);}

SerilogSerilog是一个强大的日志库,支持多种日志级别和输出格式。

集成将Serilog集成到.Net 6项目中非常简单,只需在Startup.cs中添加相应的服务即可。

完成的来查看效果完成以上步骤后,可以在控制台或日志文件中查看日志输出效果。

目录
  • 介绍
  • 正文
  • 对比
    • 向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) .ConfigureServices(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>();

    .Net 6相比之前版本有哪些长尾词写法上的改变?

    日志记录

    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 = WebApplication.CreateBuilder(args); builder.Services.AddScoped<IHelloService, HelloService>(); // Add services to the container. builder.Services.AddControllers(); // Learn more about configuring Swagger/OpenAPI at 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();

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

    本文共计960个文字,预计阅读时间需要4分钟。

    .Net 6相比之前版本有哪些长尾词写法上的改变?

    目录介绍正文对比向DI添加服务日志记录Serilog集成完成的来查看效果介绍vs2022正式版已推出,预计很多人已下载并开始创建.Net 6项目,本节简要介绍。

    正文本节将简要介绍如何使用Serilog进行日志记录,并集成到.Net 6项目中。

    对比对比其他日志库,Serilog提供了更多灵活性和可扩展性。

    向DI添加服务在Startup.cs中,可以通过以下方式添加Serilog服务到DI容器:

    csharppublic void ConfigureServices(IServiceCollection services){ services.AddLogging(loggingBuilder=> { loggingBuilder.ClearProviders(); loggingBuilder.AddSerilog(); });}

    日志记录使用Serilog进行日志记录非常简单,如下所示:

    csharppublic void LogInformation(){ Log.Information(This is an informational message.);}

    SerilogSerilog是一个强大的日志库,支持多种日志级别和输出格式。

    集成将Serilog集成到.Net 6项目中非常简单,只需在Startup.cs中添加相应的服务即可。

    完成的来查看效果完成以上步骤后,可以在控制台或日志文件中查看日志输出效果。

    目录
    • 介绍
    • 正文
    • 对比
      • 向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) .ConfigureServices(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>();

      .Net 6相比之前版本有哪些长尾词写法上的改变?

      日志记录

      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 = WebApplication.CreateBuilder(args); builder.Services.AddScoped<IHelloService, HelloService>(); // Add services to the container. builder.Services.AddControllers(); // Learn more about configuring Swagger/OpenAPI at 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();

      以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。