我有一个MVC 6网站(asp.net core / 5),我需要在剃须刀页面上检查用户是否处于特定角色。每当我致电时User.IsInRole("{rolename}")
,每次都会返回false。如果我只是调用RoleRepository,它就可以正常工作。
我是否需要重写User.IsInRole()
某个功能,或者该方法在ASP.NET Core中已经过时了?
到目前为止,这是我的实现:
if (User.IsInRole("Admin") || User.IsInRole("SuperUser") || User.IsInRole("DataIntegrity"))
{
model.IsDataIntegrity = true;
}
当我通过“授权”策略调用它时,此方法可以正常工作,如下所示:
[Authorize("DataIntegrity")]
[ValidateAntiForgeryToken]
[HttpPost]
[Route("team/edit/{schoolId:int:min(1)}/{schoolName?}")]
public async Task<IActionResult> Edit(SchoolEditViewModel model)
{
model.SchoolInfo = await _schoolRepo.GetSchoolInfo(model.SchoolId, _currentSeason);
IsModelValid(model);
if (!ModelState.IsValid)
{
return View(await ApplyUnboundProperties(model));
}
await SaveSchool(model);
return RedirectToAction("Live", "SchoolMain", new {schoolId = model.SchoolId, schoolName = model.SchoolInfo.SchoolName});
}
进行更多的谷歌搜索,这是我发现的适用于我的东西:
在Asp.Net Core的Razor页面中检查登录用户AuthorizePolicy
更具体地说,我需要将IAuthorizationService注入到我的视图(或控制器)中,然后调用AuthorizeAsync方法。
(在视图中)
@inject IAuthorizationService AuthorizationService
...
@if (await AuthorizationService.AuthorizeAsync(User, "PolicyName"))
{
<p>This paragraph is displayed because you fulfilled PolicyName.</p>
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句