c# - dotnet 核心应用程序,如何使用 appsettings 文件构建到输出文件夹

标签 c# .net .net-core

我有这个错误:

Unhandled Exception: System.IO.FileNotFoundException: The configuration file 'appsettings.json' was not found and is not optional. The physical path is '/ONEDRIVE/OneDrive - SE/LuloTV/Azure Search/DemoSearchIndexer/bin/Debug/netcoreapp2.2/appsettings.json'.
   at Microsoft.Extensions.Configuration.FileConfigurationProvider.Load(Boolean reload)
   at Microsoft.Extensions.Configuration.ConfigurationRoot..ctor(IList`1 providers)
   at Microsoft.Extensions.Configuration.ConfigurationBuilder.Build()
   at DemoSearchIndexer.Program.Main(String[] args) in /ONEDRIVE/OneDrive - SE/LuloTV/Azure Search/DemoSearchIndexer/Program.cs:line 16

JSON 文件存在于源代码目录中,但是,它看起来需要在二进制文件夹中的某个位置找到该文件。

在使用 dotnet run 运行应用程序之前,我执行了 dotnet build,假设它会将 JSON 文件复制到输出构建文件夹,但事实并非如此。

enter image description here

代码是这样的:

using System;
using System.Linq;
using System.Threading;
using Microsoft.Azure.Search;
using Microsoft.Azure.Search.Models;
using Microsoft.Extensions.Configuration;
using Microsoft.Spatial;

namespace DemoSearchIndexer
{
    class Program
    {
        static void Main(string[] args)
        {
            IConfigurationBuilder builder = new ConfigurationBuilder().AddJsonFile("appsettings.json");
            IConfigurationRoot configuration = builder.Build();

            SearchServiceClient serviceClient = CreateSearchServiceClient(configuration);

            string indexName = configuration["SearchIndexName"];

            ISearchIndexClient indexClientForQueries = CreateSearchIndexClient(indexName, configuration);

            RunQueries(indexClientForQueries);

            Console.WriteLine("{0}", "Complete.  Press any key to end application...\n");
            Console.ReadKey();
        }

        private static SearchIndexClient CreateSearchIndexClient(string indexName, IConfigurationRoot configuration)
        {
            string searchServiceName = configuration["SearchServiceName"];
            string queryApiKey = configuration["SearchServiceQueryApiKey"];

            SearchIndexClient indexClient = new SearchIndexClient(searchServiceName, indexName, new SearchCredentials(queryApiKey));
            return indexClient;
        }
        private static SearchServiceClient CreateSearchServiceClient(IConfigurationRoot configuration)
        {
            string searchServiceName = configuration["SearchServiceName"];
            string adminApiKey = configuration["SearchServiceAdminApiKey"];

            SearchServiceClient serviceClient = new SearchServiceClient(searchServiceName, new SearchCredentials(adminApiKey));
            return serviceClient;
        }

        private static void RunQueries(ISearchIndexClient indexClient)
        {
            SearchParameters parameters;
            DocumentSearchResult<Role> results;

            Console.WriteLine("Search the entire index for the term 'Administrador' and return only the RoleName field:\n");

            parameters = new SearchParameters()
                         {
                             Select = new[] { "RoleName" }
                         };

            results = indexClient.Documents.Search<Role>("Administrator", parameters);

            WriteDocuments(results);

            Console.Write("Apply a filter to the index to find roles  with a rolename:Usuario, ");
            Console.WriteLine("and return the hotelId and description:\n");

            parameters = new SearchParameters()
                         {
                             Filter = "RoleName:'Partner')",
                             Select = new[] { "Id", "RoleName" }
                         };

            results = indexClient.Documents.Search<Role>("*", parameters);

            WriteDocuments(results);

            Console.Write("Search the entire index, order by a specific field (Id) ");
            Console.Write("in descending order, take the top two results, and show only rolename and id");


            parameters = new SearchParameters()
                         {
                             OrderBy = new[] { "Id desc" },
                             Select = new[] { "Id", "RoleName" },
                             Top = 2
                         };

            results = indexClient.Documents.Search<Role>("*", parameters);

            WriteDocuments(results);

            Console.WriteLine("Search the role names for the term 'Superadministrator':\n");

            parameters = new SearchParameters()
            {
                SearchFields = new[] { "RoleName" }
            };
            results = indexClient.Documents.Search<Role>("Superadministrator", parameters);

            WriteDocuments(results);
        }

        private static void WriteDocuments(DocumentSearchResult<Role> searchResults)
        {
            foreach (SearchResult<Role> result in searchResults.Results)
            {
                Console.WriteLine(result.Document);
            }

            Console.WriteLine();
        }
    }
}

最佳答案

您可以将 ItemGroup 添加到您的 csproj 文件中,它看起来像这样:

<ItemGroup>
    <None Update="appsettings.json">
        <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
    </None>
</ItemGroup>

关于c# - dotnet 核心应用程序,如何使用 appsettings 文件构建到输出文件夹,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57158895/

相关文章:

c# - 如何编写一个函数来读取 XElement.Value 并将其转换为 C# 中的指定类型?

c# - ASP.NET 无 Cookie session URL 问题仅在移动 safari 中

c# - 更改两个相关 DateTimePickers 的值时如何防止 StackOverflow 错误?

c# - 使用 EF Core 和内存数据库进行单元测试

c# - Startup.cs 返回错误的环境

c# - 标题栏不可点击 Form.TransparencyKey = White

asp.net - 由于超过 2083 个字符, Crystal 报表在 IE 中下载失败

.NET Web 客户端 400 错误

.net - 使用 MSTest Framework 测试面向 .NET Standard 1.6 及更高版本的应用程序

c# - 查询获取数据库中的特定数据