Retrieve Azure AppSettings and Connection String Settings in ASP.NET Core Apps

Raymond Raymond event 2017-10-10 visibility 16,984 comment 1
more_vert

Background

In ASP.NET Core, we can easily use user secrets to manage our password or credentials. This post will summarize the approaches we can use after the websites are deployed into Azure.

Azure AppSettings & Connection Strings

In Azure management portal, navigate your App Services. And then in SETTINGS section, click on Application settings.
In App settings section, you can setup up any key way pairs:

image

In Connection strings section, you can setup all the connection strings:

image

You can also choose the connection type:

image

These settings are injected at run time.

Access App settings and Connection strings in your application

IConfiguration

All the configurations will be injected and can accessed through IConfiguration. You can directly add IConfiguration into your controller or services. You can also inject this directly into your views.

Sample code in Controller

using AzureWebAppTest.Models;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using System.Diagnostics;

namespace AzureWebAppTest.Controllers
{
     public class HomeController : Controller
     {
         private readonly IConfiguration configuration;

        public HomeController(IConfiguration configuration)
         {
             this.configuration = configuration;
         }

        public IActionResult Index()
         {
             var appSettingTest1 = configuration["appSettingTest1"];
             var connectionStringTest1 = configuration.GetConnectionString("connectionStringTest1");

            return Json(new { appSettingTest1, connectionStringTest1 });
         }

}

Sample configuration in Azure

image

Result in Azure website

image

Sample code in View

@{
     ViewData["Title"] = "Home Page";
     Layout = null;
}
@using Microsoft.Extensions.Configuration
@inject Microsoft.Extensions.Configuration.IConfiguration configuration

<p>appSettingTest1: @configuration["appSettingTest1"]</p>
<p>connectionStringTest1: @configuration.GetConnectionString("connectionStringTest1")</p>

Result in Azure website

image

Access through environment variables

All these settings are injected into environment variables and you can access them in other programming languages by adding some prefix:

For App settings, ‘APPSETTING_’ is added to each settings. and for connection strings, there are different prefixes added for different connection types:

  • SQL Server: SQLCONNSTR_
  • MySQL: MYSQLCONNSTR_
  • SQL Database: SQLAZURECONNSTR_
  • Custom: CUSTOMCONNSTR_

For more details, please refer to: https://docs.microsoft.com/en-us/azure/app-service/web-sites-configure

Update these settings in CI/CD environment

Instead of manually updating these settings through Azure management portal, you can also Azure Resource Manager PowerShell module to implement it in a continuous integration and deployment environment. Refer the following post for examples: https://blogs.msdn.microsoft.com/tfssetup/2016/05/20/accessingupdating-azure-web-app-settings-from-vsts-using-azure-powershell/

VSTS

If you are using Visual Studio online build and release functions, you can also just install some extensions available in Visual Studio marketplace. For instance, the following link provide you the functionality to configure App settings:

 https://marketplace.visualstudio.com/items?itemName=hboelman.AzureAppServiceSetAppSettings

More from Kontext
comment Comments
V Vũ Nguyễn

access_time 2 years ago link more_vert

Your solution work like charm!

Please log in or register to comment.

account_circle Log in person_add Register

Log in with external accounts