ASP.NET Core Web API中Startup的使用技巧

Startup类和服务配置   

STARTUP CLASS AND THE SERVICE CONFIGURATION

在 Startup 类中,有两个方法:ConfigureServices 是用于服务注册,Configure 方法是向应用程序的请求管道中添加中间件。

因此,最好的方式是保持 ConfigureServices 方法简洁,并且尽可能地具有可读性。当然,我们需要在该方法内部编写代码来注册服务,但是我们可以通过使用 扩展方法 来让我们的代码更加地可读和可维护。

例如,让我们看一个注册 CORS 服务的不好方式:

 

public void ConfigureServices(IServiceCollection services)
{
   services.AddCors(options =>
   {
       options.AddPolicy("CorsPolicy", builder => builder.AllowAnyOrigin()
           .AllowAnyMethod()
           .AllowAnyHeader()
           .AllowCredentials());
   });
}

  

尽管这种方式看起来挺好,也能正常地将 CORS 服务注册成功。但是想象一下,在注册了十几个服务之后这个方法体的长度。

这样一点也不具有可读性。

一种好的方式是通过在扩展类中创建静态方法:

 

public static class ServiceExtensions
{
   public static void ConfigureCors(this IServiceCollection services)
   {
       services.AddCors(options =>
       {
           options.AddPolicy("CorsPolicy", builder => builder.AllowAnyOrigin()
               .AllowAnyMethod()
               .AllowAnyHeader()
               .AllowCredentials());
       });
   }
}

  

然后,只需要调用这个扩展方法即可:

public void ConfigureServices(IServiceCollection services)
{
   services.ConfigureCors();
}

 

  

ASP.NET Core Web API中Startup的使用技巧

上一篇:【值得收藏】分享一些免费的实用API接口


下一篇:Angular--服务