翼度科技»论坛 编程开发 .net 查看内容

使用 Asp.net core webapi 集成配置系统,提高程序的灵活和可维护性

7

主题

7

帖子

21

积分

新手上路

Rank: 1

积分
21

前言:什么是集成配置系统?

集成配置系统的主要目的是将应用程序的配置信息与代码分离,使得配置信息可以在不需要修改代码的情况下进行更改。这样可以提高应用程序的灵活性和可维护性。
ASP.NET Core 提供了一种灵活的配置系统,可以轻松地将配置信息从不同的来源加载到应用程序中,并且可以根据环境变量、命令行参数、JSON 文件、XML 文件、环境变量等不同来源来管理配置。
本文主要讲解如何在 Asp.net core webapi 中应用集成配置系统
Step By Step 步骤


  • 创建一个 ASP.NET Core webapi 项目
  • 在 SQL Server 数据库中手动创建表 T_Configs,用于保存配置信息

    • 表包含Id、Name、Value这3列
    • Id列定义为整数类型的标识列
    • Name列和Value列都定义为字符串类型
    • Name列为配置项的名字
    • Value列为配置项的值

  • 在T_Configs表中增加两行数据
    1. 1        Redis        {"ConnStr":"127.0.0.1:16379,allowadmin=true"}
    2. 2        Smtp        {"Host":"smtp.example.com", "UserName":"test", "Password":"mypass123"}
    复制代码
  • 安装并启动 Redis

  • 引用以下 Nuget 包:
    StackExchange.Redis
    System.Data.SqlClient
    Zack.AnyDBConfigProvider

  • 在项目中创建一个SmtpOptions实体类,对应Smtp的配置值
    1. public record SmtpOptions
    2. {
    3.         public string Host { get; set; }
    4.         public string UserName { get; set; }
    5.         public string Password { get; set; }
    6. }
    复制代码
  • 在项目上右击,选择【管理用户机密】,生成 Secrets.json

    • 可以看到在 .csproj 文件中生成了 UserSecretsId 节点
      1. <UserSecretsId>29c6a656-872a-40dc-9793-2a9add90e9fe</UserSecretsId>
      复制代码
    • Secrets.json 存储在:
      1. C:\Users\Jacky\AppData\Roaming\Microsoft\UserSecrets\<UserSecretsId>29c6a656-872a-40dc-9793-2a9add90e9fe</UserSecretsId>\secrets.json
      复制代码
    • 编写 Secrets.json 内容为:
      1. {
      2.   "ConnectionStrings": { "configServer": "Server=(localdb)\\mssqllocaldb;Database=TestDB;Trusted_Connection=True;MultipleActiveResultSets=true" }
      3. }
      复制代码
    • 关闭 Secrets.json 文件后,右键重新【管理用户机密】可以再次打开 Secrets.json 文件

  • 打开 Program.cs,编写代码进行配置系统的初始化(注意,看代码注释
    1. using StackExchange.Redis;
    2. using System.Data.SqlClient;
    3. var builder = WebApplication.CreateBuilder(args);
    4. // Add services to the container.
    5. builder.Services.AddControllers();
    6. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
    7. builder.Services.AddEndpointsApiExplorer();
    8. builder.Services.AddSwaggerGen();
    9. // 1.读取用户机密文件中的sqlserver连接串
    10. builder.Host.ConfigureAppConfiguration((_, configBuilder) => {
    11.         string connStr = builder.Configuration.GetConnectionString("configServer");
    12.         configBuilder.AddDbConfiguration(() => new SqlConnection(connStr));
    13. });
    14. // 2.采用直接读取builder.Configuration的方式来读取数据库中的配置,并注册服务
    15. builder.Services.Configure<SmtpOptions>(builder.Configuration.GetSection("Smtp"));
    16. builder.Services.AddSingleton<IConnectionMultiplexer>(sp => {
    17.         string connStr = builder.Configuration.GetValue<string>("Redis:ConnStr");
    18.         return ConnectionMultiplexer.Connect(connStr);
    19. });
    20. var app = builder.Build();
    21. // Configure the HTTP request pipeline.
    22. if (app.Environment.IsDevelopment())
    23. {
    24.         app.UseSwagger();
    25.         app.UseSwaggerUI();
    26. }
    27. app.UseHttpsRedirection();
    28. app.UseAuthorization();
    29. app.MapControllers();
    30. app.Run();
    复制代码
  • 在控制器中通过构造方法注入获取SmtpOptions和Redis连接对象
    1. using Microsoft.AspNetCore.Mvc;
    2. using Microsoft.Extensions.Options;
    3. using StackExchange.Redis;
    4. namespace 配置系统集成1.Controllers
    5. {
    6.         [ApiController]
    7.         [Route("[controller]/[action]")]
    8.         public class HomeController : ControllerBase
    9.         {
    10.                 private readonly IOptionsSnapshot<SmtpOptions> smtpOptions;
    11.                 private readonly IConnectionMultiplexer connMultiplexer;
    12.                 // 通过构造方法注入获取SmtpOptions和Redis连接对象
    13.                 public HomeController(
    14.                         IOptionsSnapshot<SmtpOptions> smtpOptions,
    15.                         IConnectionMultiplexer connMultiplexer)
    16.                 {
    17.                         this.smtpOptions = smtpOptions;
    18.                         this.connMultiplexer = connMultiplexer;
    19.                 }
    20.                 // 读取配置信息,连接 Redis 读取数据
    21.                 [HttpGet]
    22.                 public async Task<string> Index()
    23.                 {
    24.                         var opt = smtpOptions.Value;
    25.                         var timeSpan = connMultiplexer.GetDatabase().Ping();
    26.                        
    27.                         //写入和读取 Key-value
    28.                         var database = connMultiplexer.GetDatabase(1);
    29.                         await database.StringSetAsync("name", "Jacky");
    30.                         string str = await database.StringGetAsync("name");
    31.                         return $"Smtp:{opt} timeSpan:{timeSpan} str:{str}";
    32.                 }
    33.         }
    34. }
    复制代码
扩展

为了简化开发,在ASP.NET Core项目中,WebApplication类的CreateBuilder方法会按照下面的顺序来提供默认的配置:

  • 加载现有的IConfiguration。
  • 加载项目根目录下的appsettings.json
  • 加载项目根目录下的appsettings.Environment.json,其中Environment代表当前运行环境的名字
  • 当程序运行在开发环境下,程序会加载“用户机密”配置
  • 加载环境变量中的配置
  • 加载命令行中的配置

来源:https://www.cnblogs.com/JackyGz/p/17990451
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具