Setup ASP.NET Core Net APIs To Use Azure AD Authentication
What are we going to do?
That is the second article within the sequence on the right way to combine an online utility that’s constructed utilizing Angular and ASP.NET core internet APIs, with Azure Lively Listing. You may see all of the elements under:
That is Half 2: Arrange Asp.web core internet APIs to make use of Azure AD Authentication. Right here I’ll clarify what code is required to combine Azure AD along with your Asp.Web Core Net API challenge.
- Should have adopted what we coated in Half 1: Arrange the Azure Lively Listing and will have the shopper and tenant Id created within the earlier article.
- Fundamental information of Asp.Web Core Net APIs.
- Should have an asp-net core internet API challenge setup.
All proper, now we’re good to go. Let’s get began.
Let’s make some code change sin the Asp.web Core Net APIs challenge.
Add the next in your appsettings.json file, and change the Area, TenentId, ClientId with the worth you copied from Azure AD.
- “AzureAd”: {
- “Occasion”: “https://login.microsoftonline.com/”,
- “Area”: “change with the area title”,
- “TenantId”: “put azure advert tenant id”,
- “ClientId”: “put your api utility’s tenant id”
- }
You may simply discover these values on the overview display screen of the api utility we registered in half 1
Subsequent let’s create two class recordsdata within the root folder of the appliance and title it AzureAdOptions, AzureAdServiceCollectionExtensions after which paste the next code respectively.
- public class AzureAdOptions
- {
- public string ClientId { get; set; }
- public string ClientSecret { get; set; }
- public string Occasion { get; set; }
- public string Area { get; set; }
- public string TenantId { get; set; }
- }
- public static class AzureAdServiceCollectionExtensions
- {
- public static AuthenticationBuilder AddAzureAdBearer(this AuthenticationBuilder builder)
- => builder.AddAzureAdBearer(_ => { });
- public static AuthenticationBuilder AddAzureAdBearer(this AuthenticationBuilder builder, Motion<AzureAdOptions> configureOptions)
- {
- builder.Providers.Configure(configureOptions);
- builder.Providers.AddSingleton<IConfigureOptions<JwtBearerOptions>, ConfigureAzureOptions>();
- builder.AddJwtBearer();
- return builder;
- }
- non-public class ConfigureAzureOptions : IConfigureNamedOptions<JwtBearerOptions>
- {
- non-public readonly AzureAdOptions _azureOptions;
- public ConfigureAzureOptions(IOptions<AzureAdOptions> azureOptions)
- {
- _azureOptions = azureOptions.Worth;
- }
- public void Configure(string title, JwtBearerOptions choices)
- {
- choices.Viewers = _azureOptions.ClientId;
- choices.Authority = $“{_azureOptions.Occasion}{_azureOptions.TenantId}”;
- }
- public void Configure(JwtBearerOptions choices)
- {
- Configure(Choices.DefaultName, choices);
- }
- }
- }
The final step is to make use of this code in startup.cs class. Paste the next code in ConfigureServices methodology.
- companies.AddAuthentication(sharedOptions =>
- {
- sharedOptions.DefaultScheme = JwtBearerDefaults.AuthenticationScheme;
- }).AddAzureAdBearer(choices => Configuration.Bind(“AzureAd”, choices));
Be sure to import the category namespace earlier than utilizing this methodology.