Azure 函数 - ConnectionString 属性尚未初始化

adl*_*val 5 connection-string azure azure-functions

我在 Visual Studio 中开发了一个 Azure Function,并且在 Azure 中发布时它可以工作(从一年前开始)。

现在,我在 Visual Studio 中从该 Azure 函数制作了一个模板,并更改了一些细节,但基本上是相同的。当我在本地测试时,效果很好。

但是当我在 Azure 中发布它并尝试测试它时,我收到此错误:

The ConnectionString property has not been initialized
Run Code Online (Sandbox Code Playgroud)

我通常在应用程序设置中编写连接字符串(它适用于较旧的 Azure 功能)。

以下是该函数如何获取连接字符串的值:

var repo = new GranularRepository(ConfigurationManager.AppSettings["BoConnectionString"]);
Run Code Online (Sandbox Code Playgroud)

我也尝试过:

var repo = new AvgDeliveryTime_GranularRepository(Environment.GetEnvironmentVariable("BodbConnectionString"));
Run Code Online (Sandbox Code Playgroud)

Joe*_*Cai 7

根据你的描述,我无法区分你的函数运行时。

对于 v1:

您可以同时使用ConfigurationManager.AppSettingsSystem.Environment.GetEnvironmentVariable来获取 Azure 中的连接字符串。

var a = ConfigurationManager.AppSettings["BoConnectionString"];
var b = System.Environment.GetEnvironmentVariable("BoConnectionString");
Run Code Online (Sandbox Code Playgroud)

对于 v2:

您可以使用System.Environment.GetEnvironmentVariableConfigurationBuilder来获取它。添加ExecutionContext参数,用于定位函数app目录。

var a= System.Environment.GetEnvironmentVariable("BoConnectionString");
/////////////
public static void Run(...,ExecutionContext context)
{
    var config = new ConfigurationBuilder()
        .SetBasePath(context.FunctionAppDirectory)
        .AddJsonFile("local.settings.json", optional: true, reloadOnChange: true)
        .AddEnvironmentVariables()
        .Build();

    // Get Connection strings
    var connParameter= "MySqlAzureConnection";
    string connectionString = config.GetConnectionString($"{connParameter}");
}
Run Code Online (Sandbox Code Playgroud)

v1 和 v2 都可以在应用程序设置中设置连接字符串。 在此输入图像描述

更详细的内容可以参考这个问题


adl*_*val 1

我通过创建一个新的 Azure Function 项目修复了该问题。

因此,我的结论是,从另一个 Azure Functions 制作模板并将其用作 Visual Studio 中的新项目会产生问题。