Microsoft.Extensions.Configuration.Binder 8.0.0-preview.3.23174.8

About

Provides the functionality to bind an object to data in configuration providers for Microsoft.Extensions.Configuration. This package enables you to represent the configuration data as strongly-typed classes defined in the application code. To bind a configuration, use the Microsoft.Extensions.Configuration.ConfigurationBinder.Get extension method on the IConfiguration object. To use this package, you also need to install a package for the configuration provider, for example, Microsoft.Extensions.Configuration.Json for the JSON provider.

For more information, see the documentation: Configuration in .NET.

Example

The following example shows how to bind a JSON configuration section to .NET objects.

using System;
using Microsoft.Extensions.Configuration;

class Settings
{
    public string Server { get; set; }
    public string Database { get; set; }
    public Endpoint[] Endpoints { get; set; }
}

class Endpoint
{
    public string IPAddress { get; set; }
    public int Port { get; set; }
}

class Program
{
    static void Main()
    {
        // Build a configuration object from JSON file
        IConfiguration config = new ConfigurationBuilder()
            .AddJsonFile("appsettings.json")
            .Build();

        // Bind a configuration section to an instance of Settings class
        Settings settings = config.GetSection("Settings").Get<Settings>();

        // Read simple values
        Console.WriteLine($"Server: {settings.Server}");
        Console.WriteLine($"Database: {settings.Database}");

        // Read nested objects
        Console.WriteLine("Endpoints: ");
        
        foreach (Endpoint endpoint in settings.Endpoints)
        {
            Console.WriteLine($"{endpoint.IPAddress}:{endpoint.Port}");
        }
    }
}

To run this example, include an appsettings.json file with the following content in your project:

{
  "Settings": {
    "Server": "example.com",
    "Database": "Northwind",
    "Endpoints": [
      {
        "IPAddress": "192.168.0.1",
        "Port": "80"
      },
      {
        "IPAddress": "192.168.10.1",
        "Port": "8080"
      }
    ]
  }
}

You can include a configuration file using a code like this in your .csproj file:

<ItemGroup>
  <Content Include="appsettings.json">
    <CopyToOutputDirectory>Always</CopyToOutputDirectory>
  </Content>
</ItemGroup>

Showing the top 20 packages that depend on Microsoft.Extensions.Configuration.Binder.

Packages Downloads
Microsoft.Extensions.Options.ConfigurationExtensions
Provides additional configuration specific functionality related to Options.
1,397
Microsoft.Extensions.Options.ConfigurationExtensions
Provides additional configuration specific functionality related to Options.
1,155
Microsoft.Extensions.Hosting
Hosting and startup infrastructures for applications.
935
Microsoft.Extensions.Logging.Configuration
Configuration support for Microsoft.Extensions.Logging.
906
Microsoft.Extensions.Hosting
Hosting and startup infrastructures for applications.
427
Microsoft.Extensions.Logging.Configuration
Configuration support for Microsoft.Extensions.Logging.
411
Microsoft.Extensions.Logging
Logging infrastructure default implementation for Microsoft.Extensions.Logging.
336
Microsoft.Extensions.Hosting
Hosting and startup infrastructures for applications.
209
Microsoft.Extensions.Options.ConfigurationExtensions
Provides additional configuration specific functionality related to Options.
206
Microsoft.Extensions.Logging.Configuration
Configuration support for Microsoft.Extensions.Logging.
205
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
60
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
58
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
49
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
47
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
41
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
34
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
22
Microsoft.Identity.Web.TokenAcquisition
Implementation for higher level API for confidential client applications (ASP.NET Core and SDK/.NET).
15

https://go.microsoft.com/fwlink/?LinkID=799421

.NET Framework 4.6.2

.NET 6.0

.NET 7.0

.NET 8.0

.NET Standard 2.0

Version Downloads Last updated
9.0.0 0 11/12/2024
9.0.0-rc.2.24473.5 4 10/19/2024
9.0.0-rc.1.24431.7 4 10/28/2024
9.0.0-preview.7.24405.7 5 08/17/2024
9.0.0-preview.6.24327.7 8 07/18/2024
9.0.0-preview.5.24306.7 5 06/22/2024
9.0.0-preview.4.24266.19 6 05/26/2024
9.0.0-preview.3.24172.9 8 04/25/2024
9.0.0-preview.2.24128.5 8 03/30/2024
9.0.0-preview.1.24080.9 8 03/26/2024
8.0.2 422 07/18/2024
8.0.1 6 03/31/2024
8.0.0 1,063 03/25/2024
8.0.0-rc.2.23479.6 8 04/25/2024
8.0.0-rc.1.23419.4 6 04/19/2024
8.0.0-preview.7.23375.6 6 04/25/2024
8.0.0-preview.6.23329.7 5 04/25/2024
8.0.0-preview.5.23280.8 8 04/04/2024
8.0.0-preview.4.23259.5 5 04/25/2024
8.0.0-preview.3.23174.8 8 04/07/2024
8.0.0-preview.2.23128.3 6 04/03/2024
8.0.0-preview.1.23110.8 8 04/03/2024
7.0.4 7 04/15/2024
7.0.3 204 03/26/2024
7.0.2 6 04/03/2024
7.0.1 6 04/20/2024
7.0.0 10 04/26/2024
7.0.0-rc.2.22472.3 7 04/25/2024
7.0.0-rc.1.22426.10 5 04/25/2024
7.0.0-preview.7.22375.6 8 04/25/2024
7.0.0-preview.6.22324.4 4 04/25/2024
7.0.0-preview.5.22301.12 7 03/31/2024
7.0.0-preview.4.22229.4 7 04/04/2024
7.0.0-preview.3.22175.4 6 04/25/2024
7.0.0-preview.2.22152.2 7 04/25/2024
7.0.0-preview.1.22076.8 7 04/03/2024
6.0.2-mauipre.1.22102.15 7 03/30/2024
6.0.2-mauipre.1.22054.8 5 04/25/2024
6.0.1 0 11/12/2024
6.0.0 1,154 03/25/2024
6.0.0-rc.2.21480.5 9 04/15/2024
6.0.0-rc.1.21451.13 5 04/25/2024
6.0.0-preview.7.21377.19 6 04/25/2024
6.0.0-preview.6.21352.12 6 04/25/2024
6.0.0-preview.5.21301.5 8 04/16/2024
6.0.0-preview.4.21253.7 8 04/25/2024
6.0.0-preview.3.21201.4 5 04/07/2024
6.0.0-preview.2.21154.6 6 04/25/2024
6.0.0-preview.1.21102.12 4 04/25/2024
5.0.0 8 04/13/2024
5.0.0-rc.2.20475.5 6 04/25/2024
5.0.0-rc.1.20451.14 7 04/25/2024
5.0.0-preview.8.20407.11 4 04/25/2024
5.0.0-preview.7.20364.11 7 04/25/2024
5.0.0-preview.6.20305.6 6 04/25/2024
5.0.0-preview.5.20278.1 9 04/25/2024
5.0.0-preview.4.20251.6 6 04/04/2024
5.0.0-preview.3.20215.2 7 04/19/2024
5.0.0-preview.2.20160.3 11 03/25/2024
5.0.0-preview.1.20120.4 6 04/25/2024
3.1.32 5 04/25/2024
3.1.31 6 04/20/2024
3.1.30 6 04/15/2024
3.1.29 5 04/26/2024
3.1.28 8 04/19/2024
3.1.27 6 04/07/2024
3.1.26 8 04/18/2024
3.1.25 5 04/12/2024
3.1.24 5 04/03/2024
3.1.23 5 05/08/2024
3.1.22 5 04/14/2024
3.1.21 7 04/22/2024
3.1.20 6 06/13/2024
3.1.19 7 04/24/2024
3.1.18 7 04/29/2024
3.1.17 6 04/14/2024
3.1.16 5 04/29/2024
3.1.15 5 04/24/2024
3.1.14 5 04/23/2024
3.1.13 3 04/04/2024
3.1.12 5 04/18/2024
3.1.11 8 04/06/2024
3.1.10 8 04/05/2024
3.1.9 5 04/26/2024
3.1.8 7 04/15/2024
3.1.7 5 04/01/2024
3.1.6 5 04/26/2024
3.1.5 6 04/26/2024
3.1.4 6 04/26/2024
3.1.3 341 03/26/2024
3.1.2 6 04/26/2024
3.1.1 7 04/18/2024
3.1.0 8 04/26/2024
3.1.0-preview3.19553.2 6 04/20/2024
3.1.0-preview2.19525.4 6 04/25/2024
3.1.0-preview1.19506.1 9 03/29/2024
3.0.3 7 04/24/2024
3.0.2 7 04/26/2024
3.0.1 8 04/26/2024
3.0.0 7 03/31/2024
3.0.0-rc1.19456.10 6 04/25/2024
3.0.0-preview9.19423.4 7 04/25/2024
3.0.0-preview8.19405.4 7 04/07/2024
3.0.0-preview7.19362.4 8 04/25/2024
3.0.0-preview6.19304.6 8 04/17/2024
3.0.0-preview5.19227.9 7 04/25/2024
3.0.0-preview4.19216.2 7 04/25/2024
3.0.0-preview3.19153.1 5 04/25/2024
3.0.0-preview.19074.2 6 04/19/2024
3.0.0-preview.18572.1 5 04/25/2024
2.2.4 6 04/18/2024
2.2.0 8 03/26/2024
2.2.0-preview3-35497 5 04/25/2024
2.2.0-preview2-35157 6 03/27/2024
2.2.0-preview1-35029 7 04/25/2024
2.1.10 7 04/10/2024
2.1.1 6 03/31/2024
2.1.0 7 04/02/2024
2.1.0-rc1-final 8 04/11/2024
2.1.0-preview2-final 6 04/23/2024
2.1.0-preview1-final 9 04/25/2024
2.0.2 6 04/25/2024
2.0.1 4 04/26/2024
2.0.0 6 04/04/2024
2.0.0-preview2-final 8 04/25/2024
2.0.0-preview1-final 6 04/05/2024
1.1.2 7 04/26/2024
1.1.1 5 04/26/2024
1.1.0 6 04/26/2024
1.1.0-preview1-final 6 04/08/2024
1.0.2 7 04/03/2024
1.0.1 7 04/02/2024
1.0.0 4 04/26/2024
1.0.0-rc2-final 7 04/03/2024
1.0.0-rc1-final 9 04/09/2024