zoukankan      html  css  js  c++  java
  • DotNetCore跨平台~关于appsettings.json里各种配置项的读取

    回到目录

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

    看一下配置文件代码段

     "JobConfig": [
        {
          "JobTypeDll": "TaskServicePool",
          "JobTypeFullName": "TaskServicePool.Jobs.SendMessageJob",
          "Cron": "0/5 * * * * ?"
        },
        {
          "JobTypeDll": "TaskServicePool",
          "JobTypeFullName": "TaskServicePool.Jobs.AsyncCustomerJob",
          "Cron": "0/10 * * * * ?"
        },
        {
          "JobTypeDll": "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;

    回到目录

    感谢各位的阅读!

  • 相关阅读:
    进程上下文VS中断上下文
    字符串分割处理
    C++接收含有空格的字符串
    TLS分析
    位运算之bit_xor、bit_not、bit_and、bit_or
    GET和POST区别
    我的 HTTP/1.1 好慢啊!
    HTTP/2与HTTP/1的比较
    C++11新特性之一— auto 和 decltype 区别和联系
    C++ tuple元组的基本用法(总结)
  • 原文地址:https://www.cnblogs.com/lori/p/7442827.html
Copyright © 2011-2022 走看看