質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
blazor

Blazorは、マイクロソフトが開発している.NETベースのWebアプリフレームワークです。C#でフロントエンドもバックエンドも一貫して書くことが可能。クライアントサイド(WebAssembly)とサーバーサイド形式のホスティングモデルがあります。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

ASP.NET

ASP.NETは動的なWebサイトやWebアプリケーション、そしてWebサービスを構築出来るようにする為、Microsoftによって開発されたウェブアプリケーション開発フレームワークです。

Q&A

解決済

1回答

3255閲覧

[blazor][ASP.NET] AppSetting の取得方法

SparklingLemon

総合スコア10

blazor

Blazorは、マイクロソフトが開発している.NETベースのWebアプリフレームワークです。C#でフロントエンドもバックエンドも一貫して書くことが可能。クライアントサイド(WebAssembly)とサーバーサイド形式のホスティングモデルがあります。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

ASP.NET

ASP.NETは動的なWebサイトやWebアプリケーション、そしてWebサービスを構築出来るようにする為、Microsoftによって開発されたウェブアプリケーション開発フレームワークです。

0グッド

0クリップ

投稿2021/05/26 09:14

前提・実現したいこと

Blazor(サーバー)にて開発を行っています。
DbContextでDB接続文字列を設定する際に、AppSettingに記載しているDB接続文字列を取得したいと
考えておりますがその方法がわかりません。

該当のソースコード

C#

1 public class PersonDbContext : DbContext 2 { 3 public DbSet<Person> Persons { get; set; } 4 5 protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) 6 { 7 if (!optionsBuilder.IsConfigured) 8 { 9 optionsBuilder.UseSqlServer(@"Server=localhost\SQLEXPRESS;Database=TEST;Trusted_Connection=True;"); 10 // ↑ 11 // ここをAppSettingから取得できるようにしたい 12 } 13 } 14 }

試したこと

Startup.csにて下記の記述があり、Configuration の値を渡すことが出来ればいいのではないかと推察していますが
具体的な方法が不明です。

C#

1 public Startup(IConfiguration configuration) 2 { 3 Configuration = configuration; 4 } 5 6 public IConfiguration Configuration { get; } 7

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

全体的にどのような構成になっているのか不明ですので具体的なことは言えませんが、基本的には DI 機能を利用してコンストラクタ経由で構成情報を DI できるはずです。

具体例は以下の記事を見てください。

WinForms で構成情報とコンテキストの DI (CORE)
http://surferonwww.info/BlogEngine/post/2021/03/30/how-to-inject-configuration-and-dbcontext-in-windows-forms-application.aspx

ASP.NET Core アプリでは作成したプロジェクトに IConfiguration オブジェクトを DI コンテナに登録し、必要に応じて Controller や Page のコンストラクタ経由で DI できる機能が実装されます。

Blazor Server はほとんど触ったことはないのでよくわかりませんが、テンプレートで生成された Program.cs を見ると同様ではないかと思われます。

【追記】

VS2019 のテンプレートで作る Blazor Server プロジェクトにも DI 機能は組み込まれるようですが、Blazor Server はステートフルという特殊事情があって、「Entity Framework Core を使用するための特別なアプローチが必要です」ということだそうです。詳しくは以下の記事を見てください。

ASP.NET Core Blazor Server と Entity Framework Core (EFCore)
https://docs.microsoft.com/ja-jp/aspnet/core/blazor/blazor-server-ef-core?view=aspnetcore-5.0

上の記事に以下のコードがあります。

services.AddDbContextFactory<ApplicationDbContext>(options => { options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")); });

試したわけではないので想像レベルですが、コンテキストクラスに以下のようなコンストラクタが定義されていて、

public partial class ApplicationDbContext : DbContext { public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) : base(options) { } // ・・・中略・・・ }

appsettings.json に、上のコードの "DefaultConnection" に該当する接続文字列情報が含まれていれば DI できるようです。

{ "ConnectionStrings": { "DefaultConnection": "接続文字列" } }

Blazor Server はステートフルという特殊事情のためいろいろ対応が必要なようです。

投稿2021/05/26 12:06

編集2021/05/27 01:04
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

SparklingLemon

2021/05/27 04:07

回答・追加情報ありがとうございます。 すぐには理解できなかったため、試行錯誤してみます。
SparklingLemon

2021/05/27 05:37

教えていただいた記事を基に接続文字列を取得することができました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問