Как перезаписать путь входа в систему при использовании проверки подлинности Azure EntraID?C#

Место общения программистов C#
Ответить
Anonymous
 Как перезаписать путь входа в систему при использовании проверки подлинности Azure EntraID?

Сообщение Anonymous »

Изучаем аутентификацию EntraID (одиночный клиент, рабочая группа), следуем онлайн-руководствам и добились того, чтобы все работало должным образом. Итак, сейчас, когда делается запрос на страницу, которая требует аутентификации, приложение направляет пользователей (я думаю, через 302) к https://login.microsoftonline.com/.../o ... /authorize конечной точке. как и ожидалось.
Теперь мне нужно разместить простую целевую страницу всякий раз, когда пользователи получают доступ к чему-то, что не авторизовано, а не переходить непосредственно к конечной точке авторизации. На целевой странице будет некоторая информация и кнопка Microsoft Sigin, которая затем свяжет пользователей с конечной точкой аутентификации (мы это запрограммируем). Какие-либо методы и/или конфигурацию, которые я могу использовать для перезаписи конечной точки перенаправленной аутентификации по умолчанию 302?
Ранее мы использовали платформу идентификации .net core EF, сохраняя учетные записи в БД и устанавливая LoginPath файла cookie приложения сработал
builder.Services.ConfigureApplicationCookie(options =>
{
options.LoginPath = new PathString("/LoginLandingPage");
});

, но теперь, когда мы попробовали EntraID, он не работает, что, я думаю, и ожидалось. Файл Program.cs, как показано ниже.
using Microsoft.Identity.Web;
using Microsoft.Identity.Web.UI;
using Microsoft.EntityFrameworkCore;
using MudBlazor.Services;
using FieldOne_AI_SomTam.Components;
using FieldOne_AI_SomTam.Data;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc.Authorization;

var builder = WebApplication.CreateBuilder(args);

// Add services to the container.
builder.Services.AddRazorComponents()
.AddInteractiveServerComponents();

builder.Services.AddMudServices();

builder.Services.AddMicrosoftIdentityWebAppAuthentication(builder.Configuration);
builder.Services.AddHttpContextAccessor();
builder.Services.AddControllersWithViews(options =>
{
var policy = new AuthorizationPolicyBuilder()
.RequireAuthenticatedUser()
.Build();
options.Filters.Add(new AuthorizeFilter(policy));
}).AddMicrosoftIdentityUI();

// This doesn't work
//builder.Services.ConfigureApplicationCookie(options =>
//{
// options.LoginPath = new PathString("/Login");
//});

builder.Services.AddCascadingAuthenticationState();

var app = builder.Build();

// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error", createScopeForErrors: true);
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}

app.UseHttpsRedirection();

app.UseStaticFiles();
app.UseAntiforgery();

app.MapRazorComponents()
.AddInteractiveServerRenderMode();

app.MapControllers();

app.Run();


Подробнее здесь: https://stackoverflow.com/questions/784 ... entication
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»