Изучаем аутентификацию 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
Как перезаписать путь входа в систему при использовании проверки подлинности Azure EntraID? ⇐ C#
Место общения программистов C#
1715583291
Anonymous
Изучаем аутентификацию EntraID (одиночный клиент, рабочая группа), следуем онлайн-руководствам и добились того, чтобы все работало должным образом. Итак, сейчас, когда делается запрос на страницу, которая требует аутентификации, приложение направляет пользователей (я думаю, через 302) к https://login.microsoftonline.com/.../oauth2/v2.0/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();
Подробнее здесь: [url]https://stackoverflow.com/questions/78470513/how-to-overwrite-the-challenge-loginpath-when-using-azure-entraid-authentication[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия