.net core 读取配置文件的几种方式

简介: # 一、Json配置文件## 1、这里的配置文件指的是下图![请在此添加图片描述](https://developer-private-1258344699.cos.ap-guangzhou.myqcloud.com/column/article/5877188/20231031-c79281ce.png?x-cos-security-token=Agam0Cn5pDWzx5RjFFzmFp5SXifE2lwa11a1f9dbaeac346ddc3b179889543979Cq1MFNxd9AGUyz-E0xgqW-YuUxnToKOaIzGnWLMcgCmVO4YvDOI5Os41fWu

一、Json配置文件

1、这里的配置文件指的是下图

请在此添加图片描述

2、json配置文件示例

{
   
   
    "Logging": {
   
   
        "LogLevel": {
   
   
            "Default": "Information",
            "Microsoft": "Warning",
            "Microsoft.Hosting.Lifetime": "Information"
        }
    },
    "Setting": {
   
   
        "Url": "http://localhost:8080/",
        "Name": "localhost"
    }
}

二、读取配置文件的几种方式

1、方式一:直接读取

[ApiController]
[Route("[controller]/[action]")]
public class TestController: ControllerBase
{
   
   
    public IConfiguration _configuration {
   
    get; set; }
    public TestController(IConfiguration configuration)
    {
   
   
        _configuration = configuration;
    }
    /// <summary>
    /// 方式一:直接读取单个值
    /// </summary>
    [HttpGet, HttpPost]
    public void GetConfigDemo1()
    {
   
   
        var url = _configuration["Setting:Url"]; // http://localhost:8080/
        var url2 = _configuration.GetValue<string>("Setting:Url"); // http://localhost:8080/
        var url3 = _configuration.GetSection("Setting").GetSection("Url").Value; // http://localhost:8080/
    }
}

2、方式二:读取Json对象

1)新建应用设置类AppSettings

/// <summary>
/// 应用设置类
/// 总类:对应json文件,确定json模块与对象
/// </summary>
public static class AppSettings
{
   
   
    public static SettingClass settingClass {
   
    get; set; }
    public static void Init(IConfiguration configuration)
    {
   
   
        // 将Setting模块绑定到Json模块的Setting类
        settingClass = new SettingClass();
        configuration.Bind("Setting", settingClass);
    }
}

2)新建Json模块Setting类

/// <summary>
/// Json模块Setting类
/// </summary>
public class SettingClass
{
   
   
    /// <summary>
    /// 地址
    /// </summary>
    public string Url {
   
    get; set; }
    /// <summary>
    /// 名称
    /// </summary>
    public string Name {
   
    get; set; }
}

3)在Startup.cs中调用AppSettings的初始化方法
请在此添加图片描述

// AppSettings总类进行调用静态方法
AppSettings.Init(Configuration);

4)在控制器中使用

[ApiController]
[Route("[controller]/[action]")]
public class TestController: ControllerBase
{
   
   
    public IConfiguration _configuration {
   
    get; set; }
    public TestController(IConfiguration configuration)
    {
   
   
        _configuration = configuration;
    }
    /// <summary>
    /// 方式二:读取Json对象 - 变成类使用
    /// </summary>
    [HttpGet, HttpPost]
    public void GetConfigDemo2()
    {
   
   
        var url = AppSettings.settingClass.Url; // http://localhost:8080/
        var name = AppSettings.settingClass.Name; // localhost
    }
}

3、方式三:在注册服务中绑定实体类与Json文件,使用时声明为全局常量

1)在Startup.cs中将Json模块类与Json文件对应内容绑定(Json模块类如方式2的SettingClass类)
请在此添加图片描述

services.Configure<SettingClass> (option =>
{
   
   
    option.Url = Configuration["Setting:Url"];
    option.Name = Configuration["Setting:Name"];
});

2)在控制器中使用

[ApiController]
[Route("[controller]/[action]")]
public class TestController: ControllerBase
{
   
   
    public IConfiguration _configuration {
   
    get; set; }
    public string UrlStr {
   
    get; set; }
    public string NameStr {
   
    get; set; }
    public TestController(IConfiguration configuration, IOptions<SettingClass> settings)
    {
   
   
        _configuration = configuration;
        UrlStr = settings.Value.Url;
        NameStr = settings.Value.Name;
    }
    /// <summary>
    /// 方法三:在注册服务的时候把配置文件与类绑定好值,使用时声明为全局常量
    /// </summary>
    [HttpGet, HttpPost]
    public void GetConfigDemo3()
    {
   
   
        var url = UrlStr; // http://localhost:8080/
        var name = NameStr; // localhost
    }
}

以上就是.net core 读取配置文件的几种方式的介绍,做此记录,如有帮助,欢迎点赞关注收藏!

目录
相关文章
|
1月前
|
存储 开发框架 JSON
ASP.NET Core OData 9 正式发布
【10月更文挑战第8天】Microsoft 在 2024 年 8 月 30 日宣布推出 ASP.NET Core OData 9,此版本与 .NET 8 的 OData 库保持一致,改进了数据编码以符合 OData 规范,并放弃了对旧版 .NET Framework 的支持,仅支持 .NET 8 及更高版本。新版本引入了更快的 JSON 编写器 `System.Text.UTF8JsonWriter`,优化了内存使用和序列化速度。
|
2月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
2月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
100 3
|
1月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
|
2月前
|
开发框架 NoSQL .NET
利用分布式锁在ASP.NET Core中实现防抖
【9月更文挑战第5天】在 ASP.NET Core 中,可通过分布式锁实现防抖功能,仅处理连续相同请求中的首个请求,其余请求返回 204 No Content,直至锁释放。具体步骤包括:安装分布式锁库如 `StackExchange.Redis`;创建分布式锁服务接口及其实现;构建防抖中间件;并在 `Startup.cs` 中注册相关服务和中间件。这一机制有效避免了短时间内重复操作的问题。
|
3月前
|
开发框架 监控 .NET
开发者的革新利器:ASP.NET Core实战指南,构建未来Web应用的高效之道
【8月更文挑战第28天】本文探讨了如何利用ASP.NET Core构建高效、可扩展的Web应用。ASP.NET Core是一个开源、跨平台的框架,具有依赖注入、配置管理等特性。文章详细介绍了项目结构规划、依赖注入配置、中间件使用及性能优化方法,并讨论了安全性、可扩展性以及容器化的重要性。通过这些技术要点,开发者能够快速构建出符合现代Web应用需求的应用程序。
58 0
|
3月前
|
缓存 数据库连接 API
Entity Framework Core——.NET 领域的 ORM 利器,深度剖析其最佳实践之路
【8月更文挑战第28天】在软件开发领域,高效的数据访问与管理至关重要。Entity Framework Core(EF Core)作为一款强大的对象关系映射(ORM)工具,在 .NET 开发中扮演着重要角色。本文通过在线书店应用案例,展示了 EF Core 的核心特性和优势。我们定义了 `Book` 实体类及其属性,并通过 `BookStoreContext` 数据库上下文配置了数据库连接。EF Core 提供了简洁的 API,支持数据的查询、插入、更新和删除操作。
116 0
|
2月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
43 7
|
2月前
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
61 0
|
3月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
49 0