加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc – 在[授权]失败后显示404错误页面

发布时间:2020-12-16 04:02:48 所属栏目:asp.Net 来源:网络整理
导读:我有一个动作,我想只限制角色“Admin”.我是这样做的: [Authorize(Roles = "Admin")]public ActionResult Edit(int id) 手动进入Controller / Edit / 1路径后,我被重定向到登录页面.嗯,这也许不错,但我想显示404而不是它,并尝试坚持使用属性.那可能吗? 解
我有一个动作,我想只限制角色“Admin”.我是这样做的:
[Authorize(Roles = "Admin")]
public ActionResult Edit(int id)

手动进入Controller / Edit / 1路径后,我被重定向到登录页面.嗯,这也许不错,但我想显示404而不是它,并尝试坚持使用属性.那可能吗?

解决方法

Is that possible?

当然,您可以编写自定义授权属性:

public class MyAuthorizeAttribute : AuthorizeAttribute
{
    protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
    {
        filterContext.Result = new ViewResult
        {
            ViewName = "~/Views/Shared/401.cshtml"
        };
    }
}

然后使用它:

[MyAuthorize(Roles = "Admin")]
public ActionResult Edit(int id)

备注:如果用户未获得授权,您可能希望显示401或403页面而不是404未找到文件.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读