appsettings.json 在 ASP.NET Core 中默认加载时,reloadOnChange 参数为 true,即支持配置文件变更自动重新加载。

好的,下面以 ASP.NET Core Web API 为例,演示如何通过 JSON 文件配置,并将类绑定到 JSON 文件内容,支持快照(IOptionsSnapshot)和依赖注入访问。

1. 添加 JSON 配置文件

假设你有一个 appsettings.json 文件,内容如下:

json 复制代码
{
  "MySettings": {
    "OptionA": "ValueA",
    "OptionB": 123
  }
}

2. 创建对应的类

csharp 复制代码
public class MySettings
{
    public string OptionA { get; set; }
    public int OptionB { get; set; }
}

3. 在 Startup.csProgram.cs 绑定配置

csharp 复制代码
var builder = WebApplication.CreateBuilder(args);

// 绑定配置到类,并注册为服务
builder.Services.Configure<MySettings>(builder.Configuration.GetSection("MySettings"));

var app = builder.Build();

4. 通过依赖注入访问(IOptionsSnapshot)

csharp 复制代码
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Options;

[ApiController]
[Route("[controller]")]
public class TestController : ControllerBase
{
    private readonly MySettings _settings;

    // IOptionsSnapshot 支持每次请求获取最新配置(适合开发环境)
    public TestController(IOptionsSnapshot<MySettings> settings)
    {
        _settings = settings.Value;
    }

    [HttpGet]
    public IActionResult Get()
    {
        return Ok(new
        {
            OptionA = _settings.OptionA,
            OptionB = _settings.OptionB
        });
    }
}

说明

  • JSON 文件:存储配置信息。
  • 类绑定 :通过 Configure<T> 方法将 JSON 配置节绑定到 C# 类。
  • 快照访问IOptionsSnapshot<T> 用于每次请求获取最新配置(适合开发环境,生产建议用 IOptions<T>)。
  • 依赖注入:控制器通过构造函数注入配置类,直接访问配置内容。

如需动态更新配置,可结合 reloadOnChange: true,但需注意生产环境的配置变更策略。

如需更详细的用法或扩展,请告知。

=============================================================================================================================================================================================================================================================================================

ASP.NET Core Web API 中,如果你想使用自定义的 xxx.json 配置文件,而不是默认的 appsettings.json,可以按照以下步骤操作:


1. 添加自定义 JSON 文件

假设你的文件名为 myconfig.json,内容如下:

json 复制代码
{
  "MySettings": {
    "OptionA": "自定义值A",
    "OptionB": 456
  }
}

2. 修改程序入口,加载自定义 JSON 文件

Program.cs 中,添加自定义配置文件:

csharp 复制代码
var builder = WebApplication.CreateBuilder(args);

// 加载自定义 JSON 文件
builder.Configuration.AddJsonFile("myconfig.json", optional: false, reloadOnChange: true);

// 绑定配置到类
builder.Services.Configure<MySettings>(builder.Configuration.GetSection("MySettings"));

var app = builder.Build();

3. 绑定类和依赖注入访问(同前例)

csharp 复制代码
public class MySettings
{
    public string OptionA { get; set; }
    public int OptionB { get; set; }
}
csharp 复制代码
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Options;

[ApiController]
[Route("[controller]")]
public class TestController : ControllerBase
{
    private readonly MySettings _settings;

    public TestController(IOptionsSnapshot<MySettings> settings)
    {
        _settings = settings.Value;
    }

    [HttpGet]
    public IActionResult Get()
    {
        return Ok(_settings);
    }
}

说明

  • 使用 AddJsonFile("myconfig.json", ...) 加载自定义配置文件。
  • 通过 builder.Configuration.GetSection("MySettings") 绑定到类。
  • 依赖注入方式访问配置内容。

这样就可以实现自定义 JSON 文件的配置绑定和注入访问。如果有更多需求可以继续补充**。**

相关推荐
泰式大师10 分钟前
7.5 万行 Rust 的 Spec 工程实践:用大模型写 Rust 时,如何把「教程味」挡在仓库外
后端
若水不如远方13 分钟前
一文讲透单点登录原理(SSO):从同域共享到跨域票据
java·后端
武子康15 分钟前
大数据-266 实时数仓-Canal + Kafka 实现 MySQL 数据库变更实时捕获
大数据·后端·kafka
丶西红柿丶16 分钟前
python-带参数和不带参数的装饰器
后端
楼田莉子17 分钟前
设计模式:构造器模式
开发语言·c++·后端·学习·设计模式
SimonKing1 小时前
大V说’AI替代不了你’,但现实是——用AI的人正在替代你
java·后端·程序员
IT_陈寒1 小时前
SpringBoot里的这个坑差点让我加班到天亮
前端·人工智能·后端
BingoGo1 小时前
Laravel13 + Vue3 的免费可商用 PHP 管理后台 CatchAdmin V5.2.0 发布
后端·php·laravel
rannn_1112 小时前
【Redis|高级篇1】分布式缓存|持久化(RDB、AOF)、主从集群、哨兵、分片集群
java·redis·分布式·后端·缓存
weixin_408099672 小时前
【实战教程】EasyClick 调用 OCR 文字识别 API(自动识别屏幕文字 + 完整示例代码)
前端·人工智能·后端·ocr·api·安卓·easyclick