page_type | name | services | platforms | urlFragment | description | languages | products | ||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
sample |
How to use an authenticated user's credentials for log-in to an Azure SQL Database from Blazor Web Server App |
active-directory |
dotnet |
ms-identity-dotnet-blazor-azure-sql |
This sample demonstrates how to use access token obtained from AAD for connecting to Azure SQL Server database as a user that is logged in into the application. |
|
|
How to use an authenticated user's credentials for log-in to an Azure SQL Database from Blazor Web Server App
Table Of Contents
- Scenario
- Prerequisites
- Setup the sample
- Troubleshooting
- Using the sample
- About the code
- How to deploy this sample to Azure
- Next Steps
- Contributing
- Learn More
This sample demonstrates a Blazor Server App querying an Azure SQL Database with the same authenticated user logged-in into the database. In other words, SQL Database will act exactly for user logged-in instead of active with administrator access rights.
- Either Visual Studio or Visual Studio Code and .NET Core SDK
- Azure subscription and Tenant with at least one user created in it
- Azure SQL Database
From your shell or command line:
git clone https://github.com/Azure-Samples/ms-identity-blazor-server.git
or download and extract the repository .zip file.
⚠️ To avoid path length limitations on Windows, we recommend cloning into a directory near the root of your drive.
-
Create an Azure SQL Database.
- The Sql database Server should have either
Use only Azure Active Directory (Azure AD) authentication
orUse both SQL and Azure AD authentication
set up as Authentication method.
- The Sql database Server should have either
-
Add one or more of this Azure AD tenant's user as or "Azure Active Directory admin". You would use this user to execute the next set of Sql statements.
-
Install SQL Server Management Studio and connect to your newly created Azure SQL database using the account you set as "Azure Active Directory admin".
-
In your newly created Database, run the following SQL statements to create and populate a database table to be used in this sample.
CREATE TABLE [dbo].[Summary]( [Summary] [nvarchar](50) NOT NULL)
Insert into [dbo].Summary values ('Freezing'),('Bracing'),('Chilly'),('Cool'),('Mild'),('Warm'),('Balmy'),('Hot'),('Sweltering'),('Scorching')
CREATE FUNCTION [dbo].[UsernamePrintFn]() RETURNS nvarchar(500) AS BEGIN declare @host nvarchar(100), @user nvarchar(100); SELECT @host = HOST_NAME() , @user = SUSER_NAME() declare @result nvarchar(500) = cast(@user + ' at ' + @host as nvarchar(500)) -- Return the result of the function return @result END
/** You can use the following command to ensure that the table and function were correctly created and work as expected **/ SELECT * FROM [dbo].Summary GO SELECT [dbo].[UsernamePrintFn] () GO
/** Create a user in database from users in your Tenant and grant them EXECUTE permission by running next set of commands. You can add more directory users to this database by running these statements repeatedly. **/ DECLARE @AADDBUser nvarchar(128) SET @AADDBUser = '<myusername>@<mytenant>.onmicrosoft.com' DECLARE @sql as varchar(max) SET @SQL = 'CREATE USER [' + @AADDBUser + '] FROM EXTERNAL PROVIDER; EXECUTE sp_addrolemember db_datareader, ''' + @AADDBUser + '''; grant execute to ''' + @AADDBUser +'''' EXEC @SQL
-
Update connection string inside appsettings.json with server and database names
-
You might need to update the database Firewall with your IP address.
There is one project in this sample. To register it, you can:
Follow the manual steps
OR
-
use PowerShell scripts that:
- automatically creates the Azure AD applications and related objects (passwords, permissions, dependencies) for you.
- modify the projects' configuration files.
Expand this section if you want to use this automation:
WARNING: If you have never used Azure AD Powershell before, we recommend you go through the App Creation Scripts guide once to ensure that your environment is prepared correctly for this step.
-
On Windows, run PowerShell as Administrator and navigate to the root of the cloned directory
-
In PowerShell run:
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope Process -Force
-
Run the script to create your Azure AD application and configure the code of the sample application accordingly.
-
For interactive process - in PowerShell run:
cd .\AppCreationScripts\ .\Configure.ps1 -TenantId "[Optional] - your tenant id" -Environment "[Optional] - Azure environment, defaults to 'Global'"
-
In case the previous script fails with error about duplicate App Registration, you might want to run the next cleanup script prior to re-running Configure.ps1
cd .\AppCreationScripts\ .\Cleanup.ps1
Other ways of running the scripts are described in App Creation Scripts guide The scripts also provide a guide to automated application registration, configuration and removal which can help in your CI/CD scenarios.
Note: skip this part if you've just used Automation steps
Follow the steps below for manually register and configure your apps
Expand this section if you want to use the steps:
- Sign in to the Azure portal.
- If your account is present in more than one Azure AD tenant, select your profile at the top right corner in the menu on top of the page, and then switch directory to change your portal session to the desired Azure AD tenant.
- Navigate to the Azure portal and select the Azure AD service.
- Select the App Registrations blade on the left, then select New registration.
- In the Register an application page that appears, enter your application's registration information:
- In the Name section, enter a meaningful application name that will be displayed to users of the app, for example
ClientApp-blazor-azuresql
.
- In the Name section, enter a meaningful application name that will be displayed to users of the app, for example
- Under Supported account types, select Accounts in this organizational directory only
- Click Register to create the application.
- In the app's registration screen, find and note the Application (client) ID. You use this value in your app's configuration file(s) later in your code.
- In the app's registration screen, select Authentication in the menu.
- If you don't have a platform added, select Add a platform and select the Web option.
- In the Redirect URI section enter the following redirect URIs:
https://localhost:44348/
https://localhost:44348/signin-oidc
- In the Front-channel logout URL section, set it to
https://localhost:44348/signout-oidc
. - Select ID tokens (used for implicit and hybrid flows) checkbox.
- Click Save to save your changes.
- In the app's registration screen, select the Certificates & secrets blade in the left to open the page where you can generate secrets and upload certificates.
- In the Client secrets section, select New client secret:
- Optionally you can type a key description (for instance
app secret
), - Select recommended Expire duration.
- The generated key value will be displayed when you select the Add button. Copy and save the generated value for use in later steps.
- You'll need this key later in your code's configuration files. This key value will not be displayed again, and is not retrievable by any other means, so make sure to note it from the Azure portal before navigating to any other screen or blade.
- Optionally you can type a key description (for instance
- Open API Permissions blade and add 'user_impersonation' scope for 'Azure SQL Database' API:
- Open Add a permission
- Switch to APIs my organization uses
- Search for Azure SQL Database
- Click on Delegated permissions
- Check user_impersonation
- Click Add permissions
Open the project in your IDE (like Visual Studio or Visual Studio Code) to configure the code.
In the steps below, "ClientID" is the same as "Application ID" or "AppId".
- Open the
Client\appsettings.json
file.- Find the key
Domain
and replace the existing value with your Azure AD tenant name. - Find the key
TenantId
and replace the existing value with your Azure AD tenant ID. - Find the key
ClientId
and replace the existing value with the application ID (clientId) ofClientApp-blazor-azuresql
app copied from the Azure portal. - Find the key
ClientSecret
and replace the existing value with the key you saved during the creation ofClientApp-blazor-azuresql
copied from the Azure portal.
- Find the key
For more information, visit Register Application AAD
To run the sample, run the following commands in the console:
cd ./WebApp-Connect-To-Azure-Sql-Database/Client
dotnet run
Expand for troubleshooting info
Use Stack Overflow to get support from the community.
Ask your questions on Stack Overflow first and browse existing issues to see if someone has asked your question before.
Make sure that your questions or comments are tagged with [azure-active-directory
adal
msal
dotnet
].
If you find a bug in the sample, please raise the issue on GitHub Issues.
To provide a recommendation, visit the following User Voice page.
Expand to see how to use the sample
Running from VS Code:
dotnet run
If you're running from Visual Studio, press F5 or Ctrl+F5 (for no debug run)
On the main page you will be offered to Log In or to go to a "Fetch data" page If you choose to go to "Fetch data" page without logging-in, you will be asked to login with a standard UI. When the application will be logged in, it will try to connect to Azure SQL Database with an Access Token it acquired for the currently logged-in user. Successful connection will be indicated when the page will state that the user is logged-in into the database and a table with mock forecast data is displayed.
The page displays a message with user and host names that are values of @user and @host on SQL Database.
Did the sample not work for you as expected? Did you encounter issues trying this sample? Then please reach out to us using the GitHub Issues page.
Expand the section
The main purpose of this sample is to show how to propagate AAD user to SQL server. The scenario is as follows:
- Get Access Token through interactive log-in process and cache it. To enable caching we have to add the 2 last lines to AAD configuration inside Program.cs:
builder.Services.AddAuthentication(OpenIdConnectDefaults.AuthenticationScheme)
.AddMicrosoftIdentityWebApp(builder.Configuration.GetSection("AzureAd"))
.EnableTokenAcquisitionToCallDownstreamApi()
.AddInMemoryTokenCaches();
- Every time, the new SQL connection is created, acquire the cached token and add it to the connection object. If the cached token is unavailable, the MsalUiRequiredException will be thrown and interactive Authorization process will be kicked-off. Here is relevant code snippet from UserAADServices.cs:
public async Task<string> GetAccessToken(AuthenticationState authState)
{
string accessToken = string.Empty;
//https://database.windows.net/.default
var scopes = new string[] { _azureSettings["Scopes"] };
try
{
var accountIdentifier = GetAccountIdentifier(authState);
IAccount account = await _app.GetAccountAsync(accountIdentifier);
AuthenticationResult authResult = await _app.AcquireTokenSilent(scopes, account).ExecuteAsync();
accessToken = authResult.AccessToken;
}
catch (MsalUiRequiredException)
{
_consentHandler.ChallengeUser(scopes);
return accessToken;
}
return accessToken;
}
Notice that the code is using a special default scope to be able to work with SQL Server - https://database.windows.net/.default
Learn how to:
- Change your app to sign-in users from any organization or any Microsoft accounts
- Enable users from National clouds to sign-in to your application
- Enable your Web App to call a Web API on behalf of the signed-in user
Additional information about AAD authentication can be found here
If you'd like to contribute to this sample, see CONTRIBUTING.MD.
This project has adopted the Microsoft Open Source Code of Conduct. For more information, see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
- Microsoft identity platform (Azure Active Directory for developers)
- Overview of Microsoft Authentication Library (MSAL)
- Authentication Scenarios for Azure AD
- Azure AD code samples
- Register an application with the Microsoft identity platform
- Building Zero Trust ready apps
For more information, visit the following links:
To learn more about the application registration, visit:
-
Quickstart: Register an application with the Microsoft identity platform
-
Quickstart: Configure a client application to access web APIs
-
To learn more about the code, visit:
-
To learn more about security in aspnetcore,