我在 Visual Studio 中开发了一个 Azure 函数,并且在 Azure 中发布时它可以工作(从一年前开始)。
现在我在 Visual Studio 中从该 Azure 函数制作了一个模板,并更改了一些细节,但基本上是相同的。当我在本地测试时,效果很好。
但是当我在 Azure 中发布它并尝试测试它时,我收到此错误:
The ConnectionString property has not been initialized
我通常在应用程序设置中编写连接字符串(它适用于较旧的 Azure 功能)。
以下是该函数如何获取连接字符串的值:
var repo = new GranularRepository(ConfigurationManager.AppSettings["BoConnectionString"]);
我也尝试过:
var repo = new AvgDeliveryTime_GranularRepository(Environment.GetEnvironmentVariable("BodbConnectionString"));
根据你的描述,我无法区分你的函数运行时。
对于 v1:
您可以同时使用
ConfigurationManager.AppSettings
和 System.Environment.GetEnvironmentVariable
来获取 Azure 中的连接字符串。
var a = ConfigurationManager.AppSettings["BoConnectionString"];
var b = System.Environment.GetEnvironmentVariable("BoConnectionString");
对于 v2:
您可以使用
System.Environment.GetEnvironmentVariable
和 ConfigurationBuilder
来获取它。添加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}");
}
更多详情,可以参考这个issue。
我通过创建一个新的 Azure Function 项目修复了该问题。
所以我的结论是,在 Visual Studio 中从另一个 Azure Function 制作模板并将其用作新项目会产生问题。
确保您的连接字符串前缀正确 -
例如:
Environment.GetEnvironmentVariable("SQLCONNSTR_MyConnectionString")