要根据角色在登录期间进行重定向,您可以使用AuthorizeAttribute和RedirectToPageResult来实现。以下是一个示例代码:
OnGet方法中添加以下代码:public IActionResult OnGet()
{
if (User.Identity.IsAuthenticated)
{
if (User.IsInRole("Admin"))
{
return RedirectToPage("/Admin/Index");
}
else if (User.IsInRole("User"))
{
return RedirectToPage("/User/Index");
}
}
return Page();
}
在此示例中,我们首先检查用户是否已经通过身份验证。然后,根据用户的角色进行重定向。如果用户是“Admin”角色,则重定向到/Admin/Index页面。如果用户是“User”角色,则重定向到/User/Index页面。否则,返回当前页面。
Authorize特性,并指定允许访问的角色:[Authorize(Roles = "Admin,User")]
public class IndexModel : PageModel
{
// ...
}
在这个示例中,我们将Authorize特性应用于IndexModel类,并指定允许访问此页面的角色。在这种情况下,允许“Admin”和“User”角色访问。
请注意,前提是您已经设置了身份验证和授权。您可以使用ASP.NET Core的内置身份验证和授权功能,或者使用第三方库如IdentityServer等。
通过以上代码示例,您可以根据角色在登录期间进行重定向。根据您的具体需求,您可以根据需要进行更改和调整。
上一篇:ASP.NET Core 2.1 Razor表单,Post请求无法到达控制器
下一篇:ASP.NET Core 2.1 REST API不接受Angular2 RequestOptionsArgs。