Core 2.0のConfigurationBuilderでBaseBasePathを設定する方法


142

Core 2.0のConfigurationBuilderでベースパスを設定するにはどうすればよいですか。

私はググってこの質問、これをMicrosoftのドキュメントから、そして2.0のドキュメントをオンラインで見つけましたが、彼らは1.0.0-beta8Microsoft.Extension.Configurationからのバージョンを使用しているようです。

読みたいですappsettings.json。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"
  }
}

更新:セットで以下に示すようにMicrosoft.Extensions.Configuration.FileExtensionsを 追加することに加えて、拡張機能を取得するためにMicrosoft.Extensions.Configuration.Jsonも追加する必要がありました。AddJsonFile


2
UPDATEが機能しました!
Chris

2
Microsoft.Extensions.Configuration.Jsonはに依存しているMicrosoft.Extensions.Configuration.FileExtensionsため、前者が必要です。
ヨハンB

友人、AddJsonFile("appsettings.json")注意してください、メソッドはあなたのホスティング環境を認識していません!.AddJsonFile($"appsettings.{_hostingEnvironment.EnvironmentName}.json")代わりに使用してください。:D
ジェス

回答:


302

SetBasePath拡張メソッドは、で定義されConfig.FileExtensions

への参照を追加する必要があります Microsoft.Extensions.Configuration.FileExtensionsパッケージます。

を解決するAddJsonFileには、Microsoft.Extensions.Configuration.Jsonパッケージへの参照を追加します。


36
しかし、今は「AddJsonFile」メソッドが見つかりません。:DIもこのパッケージを追加する必要がありました: "Microsoft.Extensions.Configuration.Json"。
Tadej 2017

5
Microsoft.Extensions.Configuration.Jsonはに依存しているMicrosoft.Extensions.Configuration.FileExtensionsため、前者が必要です。
ヨハンB

61

Visual Studio 2017 v15.5を使用して.NET Core 2コンソールアプリを開発しています。他の人が指摘したように、Microsoft.Extensions.Configurationを追加した後、AddJsonFile()呼び出しを機能させるためにMicrosoft.Extensions.Configuration.Jsonを追加する必要がありました。これにより、SetBasePath()通話も機能しました。したがって、Configuration.FileExtensionsを追加する必要はありませんでした。(私のコードは、コンパイルして実行してもしなくても実行できます。)

また、AddEnvironmentVariables()Configuration.EnvironmentVariablesを追加する必要があるへの呼び出しもありました。私のコードは次のとおりです:

  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();

興味深いことに、using私が必要とした唯一のステートメントはでしたusing Microsoft.Extensions.Configuration


11
クラスファイルで必要なusingステートメントは、Microsoft.Extensions.Configurationのみです。ただし、プロジェクトに、NuGetパッケージの管理プロジェクトオプションを使用して、NuGet依存関係「Microsoft.Extensions.Configuration.Json」を明示的に追加する必要があります。これの依存関係は「Microsoft.Extensions.Configuration.FileExtensions」であるため、依存関係の結線の一部として含まれます。これら2つの依存関係により、「SetBasePath」と「AddJsonFile」の両方のコンパイルエラーが解決されます。
グレグソニアン

Macプレビュー8のVSが現在のディレクトリをbin / netcoreapp2xに設定するため、これが機能しなくなったことを指摘するのは価値があります
Chris Becke

面倒ではなくConfiguration.EnvironmentVariables== Microsoft.Extensions.Configuration.EnvironmentVariables。同じような名前のものがいくつかあります。
Lee Richardson

12

「Microsoft.Extensions.Configuration」と「Microsoft.Extensions.Configuration.Json」の両方を使用すると、問題が解決します。

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

これが「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
} }
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.