zoukankan      html  css  js  c++  java
  • IOC容器3

    一、Options注入模式

    (相当于对appsettings.json根据字段映射到Model数据类,然后通过构造函数注入使用)

    强类型的 Options

    Options is a framework for accessing and configuring POCO settings.

    简单来说,Options 就是将一个 POCO 的配置类,通过在Startup类中注册到容器中,在后续使用的时候使用构造函数注入来获取到POCO对象。我们将这种编程模式称为Options模式。

    语法格式:services.Configure<TOptions>(Options.Options.DefaultName, config);

    TOptions作为实体类对象强类型

    首先定义一个 Options

    public class MyOptions
    {
        public string DefaultValue { get; set; }
    }

    然后我们在对应的appsettings.json中添加如下片段:

    {
      "MyOptions": {
        "DefaultValue" : "first"
      }
    }

    Startup中的ConfigureServices方法中,进行服务的注册:

    public void ConfigureServices(IServiceCollection services)  
    {
        services.Configure<MyOptions>(Configuration.GetSection("MyOptions"));
    }

    最后,便在控制器中注入IOptions<MyOptions>,通过其Value属性对MyOptions进行访问:

    [Route("api/[controller]")]
    public class ValuesController : Controller  
    {
        private readonly MyOptions _options;
        public ValuesController(IOptions<MyOptions> options)
        {
            _options = options.Value;
        }
    
        [HttpGet]
        public string Get()
        {
            return _options.DefaultValue;
        }
    }

    二、Configure 方法

    Options框架为我们提供了一系统的IServiceCollection的扩展方法,方便我们的使用。

    直接使用Action配置

    // 最简单的注册方式
    services.Configure<MyOptions>(o => o.DefaultValue = true);
    
    // 指定具体名称
    services.Configure<MyOptions>("my", o => o.DefaultValue = true);
    
    // 配置所有实例
    services.ConfigureAll<MyOptions>(o => o.DefaultValue = true);

    通过配置文件进行配置

    // 使用配置文件来注册实例
    services.Configure<MyOptions>(Configuration.GetSection("Sign"));
    
    // 指定具体名称
    services.Configure<MyOptions>("my", Configuration.GetSection("Sign"));
    
    // 配置所有实例
    services.ConfigureAll<MyOptions>(Configuration.GetSection("Sign"));

    PostConfigure方法

    PostConfigure 方法在 Configure 方法之后执行,是2.0中新增加的。

    services.PostConfigure<MyOptions>(o => o.DefaultValue = true);
    services.PostConfigure<MyOptions>("smyign", o => o.DefaultValue = true);
    services.PostConfigureAll<MyOptions>(o => o.DefaultValue = true);

    ConfigureNamedOptions

  • 相关阅读:
    出现( linker command failed with exit code 1)错误总结 (转)
    iOS 面试题
    iOS 网络-深入浅出 -> 三方SDWebImage
    免费的论文查重网站
    关于GCD中单例的实现,不仅仅是 dispatch_once(视图完整版)
    Objective
    iOS 实现代码编写中 字典属性的可读性
    iOS Category 和 Protocol 中的 Property 你们真的会了么?
    iOS 中的观察者模式之通知中心
    iOS中的 观察者模式 之 KVO
  • 原文地址:https://www.cnblogs.com/fger/p/12170301.html
Copyright © 2011-2022 走看看