Jak SetBasePath w ConfigurationBuilder w Core 2.0

142

Jak ustawić ścieżkę podstawową w ConfigurationBuilder w Core 2.0.

Przeszukałem google i znalazłem to pytanie, to z Microsoft Docs i 2.0 Docs online, ale wydaje się, że używają wersji Microsoft.Extension.Configurationod 1.0.0-beta8 .

Chcę czytać appsettings.json. Czy jest na to nowy sposób w Core 2.0?

using System;
using System.IO;
using Microsoft.Extensions.Configuration;
namespace ConsoleApp2
{
    class Program
    {
        public static IConfigurationRoot Configuration { get; set; }

        static void Main(string[] args)
        {
            var builder = new ConfigurationBuilder()
                .SetBasePath(Directory.GetCurrentDirectory()) // <== compile failing here
                .AddJsonFile("appsettings.json");

            Configuration = builder.Build();

            Console.WriteLine(Configuration.GetConnectionString("con"));
            Console.WriteLine("Press a key...");
            Console.ReadKey();
        }
    }
}

appsetting.json

{
  "ConnectionStrings": {
    "con": "connection string"
  }
}

AKTUALIZACJA: Oprócz dodania Microsoft.Extensions.Configuration.FileExtensions, jak wskazano poniżej przez Set , potrzebowałem również dodać Microsoft.Extensions.Configuration.Json, aby uzyskać AddJsonFilerozszerzenie.

Padhraic
źródło
2
UPDATE działało!
Chris Rosete
2
Microsoft.Extensions.Configuration.Jsonjest zależny Microsoft.Extensions.Configuration.FileExtensions, więc potrzebujesz tylko tego pierwszego.
Johan B
Przyjaciele, PROSZĘ PAMIĘTAĆ, że AddJsonFile("appsettings.json")metoda nie rozpoznaje Twojego środowiska hostingowego! Użyj .AddJsonFile($"appsettings.{_hostingEnvironment.EnvironmentName}.json")zamiast tego. : D
Jess

Odpowiedzi:

302

Metoda SetBasePathrozszerzenia jest zdefiniowana w Config.FileExtensions .

Musisz dodać odwołanie do pakietu Microsoft.Extensions.Configuration.FileExtensions .

Aby rozwiązać AddJsonFile, dodaj odwołanie do Microsoft.Extensions.Configuration.Jsonpakietu.

Zestaw
źródło
36
Ale teraz nie znaleziono metody „AddJsonFile”. : DI musiał dodać również ten pakiet: "Microsoft.Extensions.Configuration.Json".
Tadej
5
Microsoft.Extensions.Configuration.Jsonjest zależny Microsoft.Extensions.Configuration.FileExtensions, więc potrzebujesz tylko tego pierwszego.
Johan B
61

Tworzę aplikację konsoli .NET Core 2 przy użyciu programu Visual Studio 2017 w wersji 15,5. Jak zauważyli inni, po dodaniu Microsoft.Extensions.Configuration musiałem dodać Microsoft.Extensions.Configuration.Json, aby AddJsonFile()zadzwonić. To również sprawiło, że SetBasePath()połączenie zadziałało; więc nie musiałem dodawać Configuration.FileExtensions . (Mój kod kompiluje się i działa zarówno z nim, jak i bez niego).

Miałem też telefon AddEnvironmentVariables(), dla którego musiałem dodać Configuration.EnvironmentVariables. Mój kod wygląda następująco:

  var builder = new ConfigurationBuilder()
                    .SetBasePath(Directory.GetCurrentDirectory()) // requires Microsoft.Extensions.Configuration.Json
                    .AddJsonFile("appsettings.json") // requires Microsoft.Extensions.Configuration.Json
                    .AddEnvironmentVariables(); // requires Microsoft.Extensions.Configuration.EnvironmentVariables
  Configuration = builder.Build();

Co ciekawe, jedynym usingstwierdzeniem, którego potrzebowałem, było using Microsoft.Extensions.Configuration.

Ed Graham
źródło
11
Jedyną instrukcją używającą niezbędną w pliku klasy powinna być Microsoft.Extensions.Configuration. Jednak do projektu należy jawnie dodać zależność NuGet „Microsoft.Extensions.Configuration.Json” za pośrednictwem opcji projektu Zarządzaj pakietami NuGet. Zależnością tego jest „Microsoft.Extensions.Configuration.FileExtensions” i dlatego zostanie uwzględniona jako część połączenia zależności. Te dwie zależności rozwiążą zarówno błędy kompilacji „SetBasePath”, jak i „AddJsonFile”.
gregsonian
Warto zauważyć, że to już nie działa, ponieważ VS for Mac Preview 8 ustawia bieżący katalog na bin / netcoreapp2x
Chris Becke
Nie pedantyczny, ale Configuration.EnvironmentVariables== Microsoft.Extensions.Configuration.EnvironmentVariables. Jest kilka rzeczy o podobnych nazwach.
Lee Richardson
12

Użyj zarówno „Microsoft.Extensions.Configuration”, jak i „Microsoft.Extensions.Configuration.Json”, aby rozwiązać problem.

https://www.nuget.org/packages/Microsoft.Extensions.Configuration/ https://www.nuget.org/packages/Microsoft.Extensions.Configuration.Json/

Oto przykład „ConnectionFactory”

using System.Data;
using System.Data.SqlClient;
using Microsoft.Extensions.Configuration;
using System.IO;

namespace DataAccess.Infrastructure
{
 public class ConnectionFactory : IConnectionFactory
 {
    public ConnectionFactory()
    {
        var builder = new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile("appsettings.json");
        Configuration = builder.Build();
    }


    public IConfigurationRoot Configuration { get; }
    public IDbConnection GetConnection
    {
        get
        {
            var connectionString = Configuration.GetConnectionString("DefaultConnection");
            var conn = new SqlConnection(connectionString);
            conn.Open();
            return conn;
        }
    }

    #region IDisposable Support
    private bool disposedValue = false; // To detect redundant calls

    protected virtual void Dispose(bool disposing)
    {
        if (!disposedValue)
        {
            if (disposing)
            {
                // TODO: dispose managed state (managed objects).
            }


            // TODO: free unmanaged resources (unmanaged objects) and override a finalizer below.
            // TODO: set large fields to null.

            disposedValue = true;
        }
    }

    // TODO: override a finalizer only if Dispose(bool disposing) above has code to free unmanaged resources.
    // ~ConnectionFactory() {
    //   // Do not change this code. Put cleanup code in Dispose(bool disposing) above.
    //   Dispose(false);
    // }

    // This code added to correctly implement the disposable pattern.
    public void Dispose()
    {
        // Do not change this code. Put cleanup code in Dispose(bool disposing) above.
        Dispose(true);
        // TODO: uncomment the following line if the finalizer is overridden above.
        // GC.SuppressFinalize(this);
    }
    #endregion
} }
Anish Manchappillil
źródło