BlazorServerwithIdentity权限授权重定向循环
创始人
2024-12-21 15:30:35
0

在ASP.NET Core Blazor Server应用程序中,通过Identity管理身份验证和访问控制是很常见的。但是,在进行授权验证时,很容易出现重定向循环。以下是几种解决这个问题的方法:

方法一:添加忽略筛选器 在Startup.cs文件的ConfigureServices方法中添加忽略筛选器:

services.AddControllersWithViews(options =>
{
    var policy = new AuthorizationPolicyBuilder()
                     .RequireAuthenticatedUser()
                     .Build();
    options.Filters.Add(new AuthorizeFilter(policy));
})
.IgnoreAntiforgeryToken();

方法二:跳过自定义授权页面 在中间件管道中添加一个过滤器,以跳过授权页面并直接访问需要授权的页面:

app.Use(async (context, next) =>
{
    var path = context.Request.Path.Value;
    if (path.StartsWith("/Identity/Account") 
        && path.Contains("/login") 
        && context.Response.StatusCode == 200
        && context.User?.Identity?.IsAuthenticated != true)
    {
        context.Response.Redirect("/Identity/Account/Login");
        return;
    }
    await next();
});

方法三:更新Cookie策略 在应用程序中,通过设置Cookie策略来管理身份验证。在Startup.cs文件的ConfigureServices方法中,通过将Cookie策略设置为"None"来解决重定向循环问题:

services.ConfigureApplicationCookie(options =>
{
    options.Cookie.Name = ".AspNetCore.Identity.Application";
    options.Cookie.SameSite = SameSiteMode.None;
    options.Cookie.SecurePolicy = CookieSecurePolicy.None;
});

无论采用哪种方法,都应该确保当前用户已经被授权,避免进入重定向循环。

相关内容

热门资讯

五分钟绝活!潮友会鱼虾蟹怎么发... 五分钟绝活!潮友会鱼虾蟹怎么发现软件控制,四川家园游戏辅助,教你攻略(有挂解密)-哔哩哔哩1、操作简...
第九分钟策略!广西友乐app辅... 第九分钟策略!广西友乐app辅助工具,湖北卡五星技能,普及教程(有挂讲解)-哔哩哔哩1、全新机制【广...
4分钟要领!八闽掌上辅助软件,... 4分钟要领!八闽掌上辅助软件,对战互娱有辅助吗,揭秘攻略(有挂方针)-哔哩哔哩1、完成八闽掌上辅助软...
3分钟机巧!财神十三章辅助软件... 3分钟机巧!财神十三章辅助软件,指尖捕鱼bgm,可靠教程(有挂助手)-哔哩哔哩;1、财神十三章辅助软...
七分钟模块!胡易决胜麻架辅助,... 七分钟模块!胡易决胜麻架辅助,情怀宜春辅助挂定制交易平台,玩家教你(有挂秘籍)-哔哩哔哩1、玩家可以...
3分钟烘培!牵手辅助神器下载,... 3分钟烘培!牵手辅助神器下载,新海贝之城app破解,教你教程(有挂总结)-哔哩哔哩新海贝之城app破...
第七分钟课程!悠闲游戏辅助,牛... 第七分钟课程!悠闲游戏辅助,牛总管手游辅助,爆料教程(有挂存在)-哔哩哔哩亲,关键说明,牛总管手游辅...
3分钟演示!麻雀智能辅助软件,... 3分钟演示!麻雀智能辅助软件,传送屋激k有挂吗,力荐教程(今日头条)-哔哩哔哩1、每一步都需要思考,...
第8分钟经验!好友赣南辅助是真... 第8分钟经验!好友赣南辅助是真的吗,蛮王大厅辅助教程,分享教程(有挂教学)-哔哩哔哩1、起透看视 好...
九分钟法门!中至赣牌圈五十k黑... 九分钟法门!中至赣牌圈五十k黑科技,开心泉州小程序有挂吗,力荐教程(有挂解密)-哔哩哔哩小薇(透视辅...