.net6依赖注入方式进行实时读取 程序配置

依赖注入 实时读取配置,包括但不限 以下格式

1. json  2. ini 3. xml 4 .config 5. 环境变量 6. 命令行 等

本文章 所有的 nuget包在 文章最底层  会详细说明用处

第一步:

1、以下面 json格式为示例进行演示

json格式为以下,命名为 config.json

{
  "name": "清风扬",
  "age": 18,
  "address": {
    "adr": "192.168.135.15",
    "port": 80,
    "hy": [
      "192.168.1.101",
      "192.168.1.102",
      "192.168.1.103",
      "192.168.1.104"
    ]
  }
}

2 、配置出 json对应的C#实体类

namespace ConsoleApp1
{
    public class MyConfig
    {
        public string Name { get; set; }
        public string Age { get; set; }
        public MyAddress Address { get; set; }
    }
    public class MyAddress
    {
        public string Adr { get; set; }
        public string Port { get; set; }
        public string[] Hy { get; set; }
    }
}

3 、依赖注入  实现类

using Microsoft.Extensions.Options;

namespace ConsoleApp1
{
    public class BuildOut
    {
        //这里的 MyConfig 是上面对应的 json实体设置的 MyConfig类
        //记住IOptionsSnapshot 这个在于 某一范围外实时更新配置 下面代码会详细说明 
        private IOptionsSnapshot<MyConfig> _snapshot;
        
        //这个是BuildOut构造函数 ,构造函数作为依赖注入
        public BuildOut(IOptionsSnapshot<MyConfig> snapshot)
        {
            this._snapshot = snapshot;
        }
        //下面方法 用于 把所有 配置 打印出来
        public  void Test()
        {
            Console.WriteLine(_snapshot.Value.Name);
            Console.WriteLine(_snapshot.Value.Age);
            Console.WriteLine(_snapshot.Value.Address.Adr);
            Console.WriteLine(_snapshot.Value.Address.Port);
            if (_snapshot.Value.Address.Hy.Length > 0)
            {
                Console.WriteLine(_snapshot.Value.Address.Hy[0]);
                Console.WriteLine(_snapshot.Value.Address.Hy[1]);
            }
        }
    }
}

第二步 

以上基本 工作 做完 就 可以 开始 写 代码了。

using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;

namespace ConsoleApp1
{
    internal class Program
    {
        static void Main(string[] args)
        {
            ServiceCollection services = new ServiceCollection();
            //下面这个对应添加范围的依赖注入项,<BuildOut>可以对应上面 第一步查找
            services.AddScoped<BuildOut>();
            ConfigurationBuilder builder = new ConfigurationBuilder();
//下面注释 掉的 可以任选一个 打开注释
//var root = builder.AddEnvironmentVariables().Build(); //这个是环境变变量配置
var root = builder.AddCommandLine(args).Build(); //这个是命令行配置
//下面是Json配置 config.json文件在程序根目录下
//var root = builder.AddJsonFile("config.json", optional: true, reloadOnChange: true).Build(); 
            //添加配置项 <MyConfig>可以对应上面 第一步查找
            services.AddOptions().Configure<MyConfig>(e=>root.Bind(e));
            using (var sp = services.BuildServiceProvider())
            {
             using (IServiceScope scope = sp.CreateScope())
             {
                BuildOut build = scope.ServiceProvider.GetRequiredService<BuildOut>();
                build.Test();
             }  //出了这个 using 修改配置立马 更新
                
            }
        }
    }
}

上面mian 函数中 打开的是 命令行配置,但是注意下 传参!下面 把 第一步的json 做示例 演示下

ConsoleApp1.exe name=筱筱 age=28 address:adr=192.168.10.126 address:port=60 address:hy:0=192.168.0.1 address:hy:1=192.168.0.2 address:hy:2=192.168.0.3

这是  命令行参数转换为json  的扁平化处理

上面的扁平化 也适合 环境变量的方式

第三步

解释下 所 引用的包

Microsoft.Extensions.Configuration  必须的

Microsoft.Extensions.Configuration.Binder 必须的

Microsoft.Extensions.DependencyInjection 必须的

Microsoft.Extensions.Options 必须的

Microsoft.Extensions.Configuration.CommandLine 可选的,如果需要命令行 配置 安装这个

Microsoft.Extensions.Configuration.EnvironmentVariables 可选的,如果需要环境变量配置 安装这个

Microsoft.Extensions.Configuration.Json 可选的,如果需要 json配置 安装这个

Microsoft.Extensions.Configuration.Ini 可选的,如果需要 ini配置 安装这个

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个使用 Autofac 读取配置文件并动态注入 IOC 的示例代码(基于 .NET Framework 4.6.1)。 首先,我们需要安装 Autofac 的 NuGet 包。在 Visual Studio 中,可以通过 NuGet 包管理器搜索并安装 Autofac。 然后,我们需要创建一个配置文件来定义我们的依赖项。假设我们的配置文件是一个 JSON 文件,如下所示: ```json { "dependencies": [ { "interface": "MyNamespace.IMyService", "type": "MyNamespace.MyService" } ] } ``` 在这个配置文件中,我们定义了一个名为 `dependencies` 的数组,其中包含一个或多个对象。每个对象都具有两个属性:`interface` 和 `type`。`interface` 属性指定依赖项的接口类型,`type` 属性指定依赖项的实现类型。 接下来,我们需要编写代码来读取配置文件并注册依赖项。下面是一个简单的示例: ```csharp using System.IO; using System.Reflection; using Autofac; using Newtonsoft.Json; public static class ContainerBuilderExtensions { public static void RegisterDependenciesFromConfigFile(this ContainerBuilder builder, string configFile) { var assembly = Assembly.GetExecutingAssembly(); var configPath = Path.Combine(Path.GetDirectoryName(assembly.Location), configFile); var json = File.ReadAllText(configPath); var dependencies = JsonConvert.DeserializeObject<dynamic>(json).dependencies; foreach (var dependency in dependencies) { var interfaceType = Type.GetType(dependency.interface.Value); var implementationType = Type.GetType(dependency.type.Value); builder.RegisterType(implementationType).As(interfaceType); } } } ``` 这个扩展方法将会读取指定的配置文件,并将其中定义的依赖项注册到 Autofac 的容器中。我们可以在应用程序的启动代码中调用这个方法,以便动态注入依赖项。 ```csharp var builder = new ContainerBuilder(); builder.RegisterDependenciesFromConfigFile("dependencies.json"); var container = builder.Build(); // 从容器中解析需要的依赖项 var service = container.Resolve<IMyService>(); ``` 在这个示例中,我们首先创建了一个 `ContainerBuilder` 对象,并注册了一个扩展方法 `RegisterDependenciesFromConfigFile`。然后,我们在应用程序的启动代码中调用这个方法,并使用 `Build` 方法构建一个 Autofac 容器。最后,我们可以通过调用 `Resolve` 方法来从容器中解析需要的依赖项。 注意,我们在这个示例中使用了 Newtonsoft.Json 库来解析 JSON 配置文件。我们还使用了 `Assembly.GetExecutingAssembly().Location` 来获取当前执行程序的路径,然后使用 `Path.Combine` 和 `File.ReadAllText` 方法来读取配置文件。你也可以使用其他方法来读取配置文件,例如使用 `ConfigurationManager` 类或使用 `System.Text.Json` 库。 希望这个示例能够帮助你了解如何使用 Autofac 读取配置文件并动态注入依赖项。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值