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 文件的配置绑定和注入访问。如果有更多需求可以继续补充**。**

相关推荐
千寻girling1 分钟前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
南风9992 分钟前
Claude code安装使用保姆级教程
后端
爱泡脚的鸡腿3 分钟前
Node.js 拓展
前端·后端
蚂蚁背大象1 小时前
Rust 所有权系统是为了解决什么问题
后端·rust
子玖3 小时前
go实现通过ip解析城市
后端·go
Java不加班3 小时前
Java 后端定时任务实现方案与工程化指南
后端
心在飞扬3 小时前
RAG 进阶检索学习笔记
后端
Moment3 小时前
想要长期陪伴你的助理?先从部署一个 OpenClaw 开始 😍😍😍
前端·后端·github
Das1_3 小时前
【Golang 数据结构】Slice 底层机制
后端·go