首页 > 解决方案 > 如何在 ASP.NET Core 3.1 的 IAuthorizationHandler 中访问会话数据?

问题描述

我在自定义授权处理程序中访问会话数据时遇到困难,而它在其他地方工作。

会话在控制器操作中正常工作,但是当我尝试使用 in 访问它时IHttpContextAccessor.HttpContext.SessionMyAuthorizationHandler.HandleRequirementAsync我得到InvalidOperationException“尚未为此应用程序或请求配置会话。”。IHttpContextAccessor可以访问查询、cookie 等 - 但无法访问会话数据。

如果我尝试从控制器访问相同MyAuthorizationHandler的 ' IHttpContextAccessor,则会话数据可用。

MyAuthorizationHandler作为一个单例注入ConfigureServices,初始化的完整顺序:

public void ConfigureServices(IServiceCollection services)
{
    services.AddDistributedMemoryCache(); 
    services.AddSession(); 
    services.AddDefaultIdentity...
    services.AddControllersWithViews();
    services.AddRazorPages();
    services.AddControllers...
    services.AddAuthentication...
    services.AddAuthorization...
    services.AddHttpContextAccessor(); 
    services.AddSingleton<IAuthorizationHandler, MyAuthorizationHandler>(); 
    services.Configure<CookiePolicyOptions>...
    services.AddMvc(o => o.EnableEndpointRouting = false);
}

public void Configure(...)
{
    app.UseRouting();
    app.UseAuthentication();
    app.UseAuthorization();
    app.UseSession();
    app.UseEndpoints...
    app.UseMvc();
}

注意:我不能在这个处理程序中使用声明,我需要会话数据。

标签: c#asp.net-coreasp.net-core-3.1asp.net-authorization

解决方案


的顺序 app.UseSession();不正确,你应该把它放在任何使用会话的中间件之前。

public void Configure(...)
{
   app.UseSession();

   app.UseRouting();
   app.UseAuthentication();
   app.UseAuthorization();

   app.UseEndpoints...
   app.UseMvc();
}

推荐阅读