gpt4 book ai didi

c# - 如何将 JSON 文件读入指定值的字符串并使用 System.Text.Json?

转载 作者:行者123 更新时间:2023-12-05 00:46:26 25 4
gpt4 key购买 nike

我有一个带有 SQL Server 连接的 .Net Core 3.1 控制台应用程序(不是 ASP.NET Core),其中连接字符串存储在 appsettings.json 文件中

{"ConnectionStrings": { "DefaultConnection":"Server=sqlserver;Database=appDb;User=username;Password=password;" }}

之前我使用 Json.Net 读取字符串

var connString = JObject.Parse(File.ReadAllText("appsettings.json")).GetValue("ConnectionStrings").SelectToken("DefaultConnection").ToString()

而且效果很好。现在我决定切换到 System.Text.Json 库并遇到动态反序列化问题。以下代码抛出异常:

var dict = JsonSerializer.Deserialize<Dictionary<string, string[]>>("appsettings.json");

System.Text.Json.JsonException: ''a' is an invalid start of a value. Path: $ | LineNumber: 0 | BytePositionInLine: 0.' Inner Exception JsonReaderException: 'a' is an invalid start of a value. LineNumber: 0 | BytePositionInLine: 0.

然后我会从字典中读取指定 Where Key == "ConnectionStrings",然后是字符串数组的后续值 == "DefaultConnection"。由于异常,我还没有达到那个点,所以我还没有计划如何从字典中阅读。

如何使用新的 System.Text.Json 库从 appsettings.json 文件中读取连接字符串?反序列化为 Dictianory<string, string[]> 是否正确?或者最好使用Dictianory<string, Dictianory<string, string>> ?

最佳答案

JsonSerializer.Deserialize 需要 JSON 字符串,而不是文件名。

您需要将文件加载到字符串中,然后将其传递给 Deserialize 方法:

var json = File.ReadAllText("appsettings.json");
var dict = JsonSerializer.Deserialize<Dictionary<string, string[]>>(json);

关于c# - 如何将 JSON 文件读入指定值的字符串并使用 System.Text.Json?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60509292/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com