加载appsettings.json文件

文章展示了如何在.NETCore控制台应用中引用NuGet包,如`Microsoft.Extensions.Configuration`系列,创建并使用appsettings.json文件来存储配置信息。通过`ConfigurationBuilder`构建配置,然后通过静态实例访问配置值,如连接字符串和自定义设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 引用NuGet

 Microsoft.Extensions.Configuration

 Microsoft.Extensions.Configuration.FileExtensions

 Microsoft.Extensions.Configuration.Json

 在控制台应用项目下,创建appsettings.json

1

2

3

4

5

6

7

8

{

  "ConnectionStrings": {

    "dbName""server=localhost;database=hr;PORT=3306;uid=root;pwd=123456;charset=gb2312"

  },

  "AppSettings": {

    "Url""12"

  }

}

 特别注意:

创建调用类及调用方式

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

using Microsoft.Extensions.Configuration;

using System;

using System.IO;

namespace CustomAttributes.Model

{

    public class Appsettings

    {

        private IConfigurationRoot Configuration;

        private Appsettings()

        {

            var builder = new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile("appsettings.json");

            Configuration = builder.Build();

        }

        private static readonly Lazy<Appsettings> InstanceLock = new Lazy<Appsettings>(() => new Appsettings()

        {

        });

        public static Appsettings Instance

        {

            get

            {

                return InstanceLock.Value;

            }

        }

        public string GetByKey(string key)

        {

            return Configuration.GetSection(key).Value;

        }

        public string GetConnectionString()

        {

            return Configuration.GetConnectionString("dbName");

        }

    }

}

  

1

2

3

4

5

6

7

8

9

10

11

12

13

14

using CustomAttributes.Model;

using System;

namespace CustomAttributesApp

{

    class Program

    {

        static void Main(string[] args)

        {

            Console.WriteLine(Appsettings.Instance.GetByKey("AppSettings:Url"));

            Console.WriteLine(Appsettings.Instance.GetConnectionString());

        }

    }

}

  

`appsettings.json`是ASP.NET Core项目中常用的配置文件,用于存储应用的各种设置,例如数据库连接字符串、API端点、环境变量等。它的基本用法如下: 1. **创建文件**:首先,在项目的根目录下创建一个名为`appsettings.json`的新文件,如果没有默认模板会自动生成。它通常是键值对的形式,每个键对应一个设置。 ```json { "ConnectionStrings": { "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=MyDB;Trusted_Connection=True;", }, "Logging": { "LogLevel": { "Default": "Information", "Microsoft": "Warning", "Microsoft.Hosting.Lifetime": "Information" } } } ``` 2. **读取设置**:在你的代码中,使用`ConfigurationBuilder`和`IConfiguration`接口来加载并读取`appsettings.json`中的值。 ```csharp var builder = new ConfigurationBuilder() .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true) .Build(); string connectionString = builder.GetValue<string>("ConnectionStrings:DefaultConnection"); ``` 3. **环境变量区分**:`appsettings.json`可以根据环境(Development, Production等)有不同的版本,只需在文件名前加上环境名称,如`appsettings.Development.json`或`appsettings.Production.json`。 4. **注入依赖**:如果你的应用有依赖于配置的服务,可以在启动时通过`IServiceCollection`注入`IConfiguration`,然后直接从配置中获取值。 ```csharp services.AddSingleton<IConfiguration>(builder.Build()); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值