回答編集履歴

1

追記

2021/05/27 01:04

投稿

退会済みユーザー
test CHANGED
@@ -17,3 +17,87 @@
17
17
 
18
18
 
19
19
  Blazor Server はほとんど触ったことはないのでよくわかりませんが、テンプレートで生成された Program.cs を見ると同様ではないかと思われます。
20
+
21
+
22
+
23
+ **【追記】**
24
+
25
+
26
+
27
+ VS2019 のテンプレートで作る Blazor Server プロジェクトにも DI 機能は組み込まれるようですが、Blazor Server はステートフルという特殊事情があって、「Entity Framework Core を使用するための特別なアプローチが必要です」ということだそうです。詳しくは以下の記事を見てください。
28
+
29
+
30
+
31
+ ASP.NET Core Blazor Server と Entity Framework Core (EFCore)
32
+
33
+ [https://docs.microsoft.com/ja-jp/aspnet/core/blazor/blazor-server-ef-core?view=aspnetcore-5.0](https://docs.microsoft.com/ja-jp/aspnet/core/blazor/blazor-server-ef-core?view=aspnetcore-5.0)
34
+
35
+
36
+
37
+ 上の記事に以下のコードがあります。
38
+
39
+
40
+
41
+ ```
42
+
43
+ services.AddDbContextFactory<ApplicationDbContext>(options =>
44
+
45
+ {
46
+
47
+ options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"));
48
+
49
+ });
50
+
51
+ ```
52
+
53
+
54
+
55
+ 試したわけではないので想像レベルですが、コンテキストクラスに以下のようなコンストラクタが定義されていて、
56
+
57
+
58
+
59
+ ```
60
+
61
+ public partial class ApplicationDbContext : DbContext
62
+
63
+ {
64
+
65
+ public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
66
+
67
+ : base(options)
68
+
69
+ {
70
+
71
+ }
72
+
73
+
74
+
75
+ // ・・・中略・・・
76
+
77
+ }
78
+
79
+ ```
80
+
81
+
82
+
83
+ appsettings.json に、上のコードの "DefaultConnection" に該当する接続文字列情報が含まれていれば DI できるようです。
84
+
85
+
86
+
87
+ ```
88
+
89
+ {
90
+
91
+ "ConnectionStrings": {
92
+
93
+ "DefaultConnection": "接続文字列"
94
+
95
+ }
96
+
97
+ }
98
+
99
+ ```
100
+
101
+
102
+
103
+ Blazor Server はステートフルという特殊事情のためいろいろ対応が必要なようです。