webapi AddOptions 服务注册说明

在.NET Core(现在是.NET 5及更高版本的一部分)中,services.AddOptions(); 这行代码是用于配置和注册选项(Options)模式的服务。选项模式允许你在应用程序的不同部分之间共享配置数据,而无需直接依赖于配置系统或硬编码值。这种方式提高了应用程序的可维护性和可测试性。

然而,需要注意的是,从ASP.NET Core 2.0开始,services.AddOptions(); 这行代码通常不是必需的,因为当你添加其他需要选项模式的服务时(如通过调用如 services.AddDbContext<TContext>(optionsAction) 或 services.Configure<TOptions>(configuration.GetSection(name)) 等方法),框架会自动为你注册所需的选项服务。

在.NET Core或.NET 5/6/7等较新版本中,如果你需要使用选项模式,你通常会这样做:

  1. 定义选项类:首先,你需要定义一个或多个选项类,这些类包含你想要在应用程序中共享的配置数据。
  2. public class MyOptions  
    {  
        public string Option1 { get; set; }  
        public int Option2 { get; set; }  
    }

  3. 配置选项:然后,在你的Startup.csConfigureServices方法中,你可以通过Configuration对象来配置这些选项。这通常是通过调用Configure<TOptions>方法完成的,该方法将配置节绑定到你的选项类上。
  4. public void ConfigureServices(IServiceCollection services)  
    {  
        services.AddControllers();  
      
        // 将appsettings.json中的"MyOptions"部分绑定到MyOptions类  
        services.Configure<MyOptions>(Configuration.GetSection("MyOptions"));  
      
        // 如果你需要绑定并立即验证配置,可以使用ConfigureAndValidate  
        // services.ConfigureAndValidate<MyOptions>(Configuration.GetSection("MyOptions"), options =>  
        // {  
        //     // 在这里添加验证逻辑  
        //     if (string.IsNullOrEmpty(options.Option1))  
        //     {  
        //         throw new OptionsValidationException("Option1 cannot be null or empty.", options);  
        //     }  
        // });  
    }

    3:调用 

  5. public class MyService  
    {  
        private readonly MyOptions _options;  
      
        // 通过构造函数注入IOptions<MyOptions>  
        public MyService(IOptions<MyOptions> options)  
        {  
            // 从IOptions<MyOptions>中获取MyOptions的实例  
            _options = options.Value;  
        }  
      
        public void DoSomething()  
        {  
            // 使用_options中的配置执行操作  
            Console.WriteLine($"Option1: {_options.Option1}, Option2: {_options.Option2}");  
        }  
    }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值