.NET7后端框架:读取配置文件

前言

在项目开发过程中,不可避免的会设置一些全局的可变的参数,如连接字符串、功能开关、Swagger配置、Redis配置等等。
.NET Core 将这些配置参数统一放在 appsettings.json 文件中进行管理,并提供了 IConfiguration 接口,在需要读取配置文件内容的类中,注入 IConfiguration 即可。
但是,.NET Core 默认是通过构造函数注入,而 appsettings.json 的内容是不会经常进行变动,如果每个需要获取配置值类,都先在构造函数注入 IConfiguration 才能使用,也挺烦的。
所以我们写一个公用类,对配置的读取进行简单的封装。

公用类

在 AMO.Core 新建文件夹 Helper 文件夹,帮助类都放此文件夹中。添加类 AppSettings.cs

using Microsoft.Extensions.Configuration;

namespace AMO.Core.Helper
{
    /// <summary>
    /// 读取配置文件帮助类
    /// </summary>
    public class AppSettings
    {
        #region 注入参数
        /// <summary>
        /// 配置文件
        /// </summary>
        private static IConfiguration? _config;
        #endregion

        #region 构造函数
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="configuration">配置文件</param>
        public AppSettings()
        {
            _config = new ConfigurationBuilder()
                    .AddJsonFile("appsettings.json", true, reloadOnChange: true)
                    .Build();
        }
        #endregion

        #region 静态方法
        /// <summary>
        /// 读取指定节点信息
        /// </summary>
        /// <param name="sessions">节点名称</param>
        /// <returns></returns>
        public static string ReadString(params string[] sessions)
        {
            try
            {
                if (_config != null && sessions.Any())
                {
                    string? str = _config[string.Join(":", sessions)];
                    if (!string.IsNullOrEmpty(str))
                    {
                        return str;
                    }
                }
            }
            catch
            {
                return string.Empty;
            }
            return string.Empty;
        }

        /// <summary>
        /// 读取实体信息
        /// </summary>
        /// <param name="sessions">节点名称</param>
        /// <returns></returns>
        public static T ReadObject<T>(params string[] sessions) where T : class, new()
        {
            T data = new();
            try
            {
                if (_config != null && sessions.Any())
                {
                    _config.Bind(string.Join(":", sessions), data);
                }
            }
            catch
            {
                return data;
            }
            return data;
        }

        /// <summary>
        /// 读取实体数组信息
        /// </summary>
        /// <param name="sessions">节点名称</param>
        /// <returns></returns>
        public static List<T> ReadList<T>(params string[] sessions) where T : class
        {
            List<T> list = new();
            try
            {
                if (_config != null && sessions.Any())
                {
                    _config.Bind(string.Join(":", sessions), list);
                }
            }
            catch
            {
                return list;
            }
            return list;
        }
        #endregion
    }
}

构造函数中,AddJsonFile 方法的 reloadOnChange 设置为 true, 当 appsettings.json 有修改的时候,不需要重启后端服务,即可获取最新值。

注册服务

在 AppStart.cs 的 Run 方法中,注册 AppSettings。生命周期为 Singleton。

        public static void Run(this WebApplicationBuilder builder)
        {
            var logger = NLog.LogManager.Setup().GetCurrentClassLogger();
            logger.Debug("[启动服务]");
            try
            {
                // 配置文件,放在第一句,并注册为Singleton
                builder.Services.AddSingleton(new AppSettings());
                // ... 其他
            }
        }

使用

修改 appsettings.json 添加测试配置

  /* 单值 */
  "FileLoad": "/nginx/fileload",
  /* 对象 */
  "Redis": {
    "Enabled": true,
    "ConnectionString": "127.0.0.1:6379,ssl=false,abortConnect=false,connectTimeout=5000",
    "DatabaseId": 10
  }

定义 Redis 配置类, 类中属性记得给默认值,避免在使用的时候出现 null 的情况。

public class RedisConfig
{
    public bool Enabled { get; set; } = false;
    public string ConnectionString { get; set; } = "127.0.0.1:6379,ssl=false,abortConnect=false,connectTimeout=5000";
    public int DatabaseId { get; set; } = 10;
}

Controller 写测试接口

[HttpGet("read-string")]
public string ReadString(string key)
{
    string data = AppSettings.ReadString(key);
    return data;
}

[HttpGet("read-object")]
public RedisConfig ReadObject(string key)
{
    RedisConfig data = AppSettings.ReadObject<RedisConfig>(key);
    return data;
}

测试结果:

获取对象
[Request URL] http://localhost:5118/WeatherForecast/read-object?key=Redis
[Server response]
{
  "enabled": true,
  "connectionString": "127.0.0.1:6379,ssl=false,abortConnect=false,connectTimeout=5000",
  "databaseId": 10
}

获取单值
[Request URL] http://localhost:5118/WeatherForecast/read-string?key=FileLoad
[Server response] /nginx/fileload

最后

以上,对 appsettings.json 进行了简单封装。你可以在任何需要获取配置的类中使用 AppSettings。

题外

近期我司开源了一套简洁又功能完整的WMS系统: ModernWMS,采用 Vue3 + TS + Vuetify + .Net7 + EF Core 框架。欢迎来踩。
在线体验地址: https://wmsonline.ikeyly.com/
Github: https://github.com/fjykTec/ModernWMS
Gitee:https://gitee.com/modernwms/ModernWMS

posted @ 2023-01-30 15:19  陈墨的码农  阅读(1357)  评论(1编辑  收藏  举报