The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



"Релиз унифицированной платформы .NET 5 с поддержкой Linux и WebAssembly"
Версия для распечатки Пред. тема | След. тема
Форум Разговоры, обсуждение новостей
Исходное сообщение [ Отслеживать ]
Присылайте удачные настройки в раздел примеров файлов конфигурации на WIKI.opennet.ru.
. "Релиз унифицированной платформы .NET 5 с поддержкой Linux и ..." +/
Сообщение от Аноним (174), 15-Ноя-20, 05:34 
Вобщем, решил вопрос:

services.AddAuthentication()
  .AddJwtBearer(JwtBearerDefaults.AuthenticationScheme, o => { ... })
  .AddCookie("Cookie", o => { ... });

services.ConfigureApplicationCookie(o =>
{
  o.ForwardDefaultSelector = ctx =>
    {
      if (ctx.Request.Query.ContainsKey("access_token") || ctx.Request.Headers.ContainsKey("Authorization"))
        return JwtBearerDefaults.AuthenticationScheme;

      return "Cookie";
    };
});

services.AddAuthorization(o =>
{
    o.AddPolicy("BearerPolicy", p => p.AddAuthenticationSchemes(JwtBearerDefaults.AuthenticationScheme)
                .RequireAuthenticatedUser()
    );
    o.AddPolicy("CookiePolicy", p => p.AddAuthenticationSchemes("Cookie")
                .RequireAuthenticatedUser()
    );
});

При логине по кукам не забыть указать схему HttpContext.SignInAsync("Cookie", ...). После этого все работает и через [Authorize(Policy = "CookiePolicy")] и через [Authorize(AuthenticationSchemes = "Cookie")] и через любую схему через [Authorize].

Спасибо вам, но не докам от МС, в которых ничего этого не рассказывается.

Ответить | Правка | Наверх | Cообщить модератору

Оглавление
Релиз унифицированной платформы .NET 5 с поддержкой Linux и WebAssembly, opennews, 11-Ноя-20, 13:32  [смотреть все]
Форумы | Темы | Пред. тема | След. тема



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру