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

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

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

集成配置系统的主要目的是将应用程序的配置信息与代码分离,使得配置信息可以在不需要修改代码的情况下进行更改。这样可以提高应用程序的灵活性和可维护性。

ASP.NET Core 提供了一种灵活的配置系统,可以轻松地将配置信息从不同的来源加载到应用程序中,并且可以根据环境变量、命令行参数、JSON 文件、XML 文件、环境变量等不同来源来管理配置。

本文主要讲解如何在 Asp.net core webapi 中应用集成配置系统

Step By Step 步骤

  1. 创建一个 ASP.NET Core webapi 项目
  2. 在 SQL Server 数据库中手动创建表 T_Configs,用于保存配置信息
  • 表包含Id、Name、Value这3列
  • Id列定义为整数类型的标识列
  • Name列和Value列都定义为字符串类型
  • Name列为配置项的名字
  • Value列为配置项的值

3.在T_Configs表中增加两行数据

1 Redis {"ConnStr":"127.0.0.1:16379,allowadmin=true"}
2 Smtp  {"Host":"smtp.example.com", "UserName":"test", "Password":"mypass123"}

4.安装并启动 Redis

5.引用以下 Nuget 包:

StackExchange.Redis

System.Data.SqlClient

Zack.AnyDBConfigProvider

6.在项目中创建一个SmtpOptions实体类,对应Smtp的配置值

public record SmtpOptions
{
  public string Host { get; set; }
  public string UserName { get; set; }
  public string Password { get; set; }
}

7.在项目上右击,选择【管理用户机密】,生成 Secrets.json

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

8.打开 Program.cs,编写代码进行配置系统的初始化(注意,看代码注释

using StackExchange.Redis;
using System.Data.SqlClient;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
// 1.读取用户机密文件中的sqlserver连接串
builder.Host.ConfigureAppConfiguration((_, configBuilder) => {
  string connStr = builder.Configuration.GetConnectionString("configServer");
  configBuilder.AddDbConfiguration(() => new SqlConnection(connStr));
});
// 2.采用直接读取builder.Configuration的方式来读取数据库中的配置,并注册服务
builder.Services.Configure<SmtpOptions>(builder.Configuration.GetSection("Smtp"));
builder.Services.AddSingleton<IConnectionMultiplexer>(sp => {
  string connStr = builder.Configuration.GetValue<string>("Redis:ConnStr");
  return ConnectionMultiplexer.Connect(connStr);
}); 
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
  app.UseSwagger();
  app.UseSwaggerUI();
}
app.UseHttpsRedirection();
app.UseAuthorization();
app.MapControllers();
app.Run();

9.在控制器中通过构造方法注入获取SmtpOptions和Redis连接对象

using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Options;
using StackExchange.Redis;
namespace 配置系统集成1.Controllers
{
  [ApiController]
  [Route("[controller]/[action]")]
  public class HomeController : ControllerBase
  {
    private readonly IOptionsSnapshot<SmtpOptions> smtpOptions;
    private readonly IConnectionMultiplexer connMultiplexer;
    // 通过构造方法注入获取SmtpOptions和Redis连接对象
    public HomeController(
      IOptionsSnapshot<SmtpOptions> smtpOptions,
      IConnectionMultiplexer connMultiplexer)
    {
      this.smtpOptions = smtpOptions;
      this.connMultiplexer = connMultiplexer;
    }
    // 读取配置信息,连接 Redis 读取数据
    [HttpGet]
    public async Task<string> Index()
    {
      var opt = smtpOptions.Value;
      var timeSpan = connMultiplexer.GetDatabase().Ping();
      
      //写入和读取 Key-value
      var database = connMultiplexer.GetDatabase(1);
      await database.StringSetAsync("name", "Jacky");
      string str = await database.StringGetAsync("name");
      return $"Smtp:{opt} timeSpan:{timeSpan} str:{str}";
    }
  }
}

扩展

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

  1. 加载现有的IConfiguration。
  2. 加载项目根目录下的appsettings.json
  3. 加载项目根目录下的appsettings.Environment.json,其中Environment代表当前运行环境的名字
  4. 当程序运行在开发环境下,程序会加载“用户机密”配置
  5. 加载环境变量中的配置
  6. 加载命令行中的配置
相关文章
|
人工智能 数据可视化 开发者
FlowiseAI:34K Star!集成多种模型和100+组件的 LLM 应用低代码开发平台,拖拽组件轻松构建程序
FlowiseAI 是一款开源的低代码工具,通过拖拽可视化组件,用户可以快速构建自定义的 LLM 应用程序,支持多模型集成和记忆功能。
1459 14
FlowiseAI:34K Star!集成多种模型和100+组件的 LLM 应用低代码开发平台,拖拽组件轻松构建程序
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
1005 13
|
Kubernetes Go 持续交付
一个基于Go程序的持续集成/持续部署(CI/CD)
本教程通过一个简单的Go程序示例,展示了如何使用GitHub Actions实现从代码提交到Kubernetes部署的CI/CD流程。首先创建并版本控制Go项目,接着编写Dockerfile构建镜像,再配置CI/CD流程自动化构建、推送Docker镜像及部署应用。此流程基于GitHub仓库,适用于快速迭代开发。
383 3
|
Kubernetes 持续交付 Go
创建一个基于Go程序的持续集成/持续部署(CI/CD)流水线
创建一个基于Go程序的持续集成/持续部署(CI/CD)流水线
|
存储 运维
.NET开发必备技巧:使用Visual Studio分析.NET Dump,快速查找程序内存泄漏问题!
.NET开发必备技巧:使用Visual Studio分析.NET Dump,快速查找程序内存泄漏问题!
476 2
|
自然语言处理 C# 图形学
使用dnSpyEx对.NET Core程序集进行反编译、编辑和调试
使用dnSpyEx对.NET Core程序集进行反编译、编辑和调试
461 0
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
1872 0
|
存储 缓存 安全
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
如何使用 PHP 将天气跟踪集成到 Web 应用程序中
238 0
|
.NET
ASP.NET WebAPi之断点续传下载(下)
前言 上一篇我们穿插了C#的内容,本篇我们继续来讲讲webapi中断点续传的其他情况以及利用webclient来实现断点续传,至此关于webapi断点续传下载以及上传内容都已经全部完结,一直嚷嚷着把SQL Server和Oracle数据库再重新过一遍,这篇过完,就要开始新的征程,每一个阶段都应该有自己的小目标,要不然当工作太忙没时间去充电,太闲又变得懒散,想想一切是为了未来买得起孩子高档的奶粉就又有动力了。
1343 0
|
.NET 数据格式
ASP.NET WebAPi之断点续传下载(中)
前言 前情回顾:上一篇我们遗留了两个问题,一个是未完全实现断点续传,另外则是在响应时是返回StreamContent还是PushStreamContent呢?这一节我们重点来解决这两个问题,同时就在此过程中需要注意的地方一并指出,若有错误之处,请指出。
1316 0