DotNetCore跨平台~关于appsettings.json里各种配置项的读取

回到目录

对于dotnet Core来说,依赖注入的集成无疑是最大的亮点,它主要用在服务注册与注入和配置文件注册与注入上面,我们一般会在程序入口先注册服务或者文件,然后在需要的地方使用注入即可,下面主要介绍一下实体配置和集合配置的方式.

看一下配置文件代码段

 "JobConfig": [
    {
      "JobTypeDll": "Pilipa.TaskServicePool",
      "JobTypeFullName": "Pilipa.TaskServicePool.Jobs.SendMessageJob",
      "Cron": "0/5 * * * * ?"
    },
    {
      "JobTypeDll": "Pilipa.TaskServicePool",
      "JobTypeFullName": "Pilipa.TaskServicePool.Jobs.AsyncCustomerJob",
      "Cron": "0/10 * * * * ?"
    },
    {
      "JobTypeDll": "Pilipa.TaskServicePool",
      "JobTypeFullName": "Pilipa.TaskServicePool.Jobs.SendEmailJob",
      "Cron": "0/1 * * * * ?"
    }
  ],

无论是实体还是集合,都应该先把配置文件注册一下

 var config = new ConfigurationBuilder()
                  .SetBasePath(Directory.GetCurrentDirectory())
                  .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
                  .Build();

实体配置的注入如下

           //实体配置
            var spOne = new ServiceCollection().AddOptions()
                        .Configure<RedisConfiguration>(config.GetSection("RedisConfiguration"))
                        .BuildServiceProvider();
            var jobConfigList2 = spOne.GetService<IOptions<RedisConfiguration>>().Value;

集合的注入如下

           //集合配置
            var spList = new ServiceCollection().AddOptions()
                         .Configure<List<JobConfig>>(config.GetSection("JobConfig"))
                         .BuildServiceProvider();
            var jobConfigList1 = spList.GetService<IOptions<List<JobConfig>>>().Value;

回到目录

感谢各位的阅读!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值