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

asp.net-mvc – 如何处理返回ViewResult以外的结果的操作的授权

发布时间:2020-12-16 03:32:26 所属栏目:asp.Net 来源:网络整理
导读:我在我的ASP.NET MVC控制器上使用自定义授权过滤器,如果用户在特定操作上失败,则会将用户重定向到登录屏幕以外的URL. 这对于返回视图的操作是可以的,但是我的许多操作都返回其他结果类型,例如PartialResult或JsonResult. 我当前的过滤器如下所示: Authorize
我在我的ASP.NET MVC控制器上使用自定义授权过滤器,如果用户在特定操作上失败,则会将用户重定向到登录屏幕以外的URL.

这对于返回视图的操作是可以的,但是我的许多操作都返回其他结果类型,例如PartialResult或JsonResult.

我当前的过滤器如下所示:

<AuthorizeWithRedirect(Roles:=”ServerAccess”,Controller:=”Home”,Action:=”Unauthorised”)>

这表示如果用户不在ServerAccess角色中,则应将其重定向到/ Home / Unauthorized /

我很好奇其他人是如何处理这个的?当您考虑仅由客户端脚本AJAX调用调用的操作数时,这似乎特别成问题. / Home / Unauthorized / action如何知道调用者是否打算接收视图,部分视图,json,内容等?

解决方法

我认为您需要通过重定向传递该信息.

有几种方法可以解决这个问题:

>考虑为您需要的每种类型的响应制作单独的操作方法 – UnauthorizedJson,UnauthorizedHtml,UnauthorizedEtc …对应于原始操作响应类型>通过向Unauthorized方法添加另一个参数并将其附加到过滤器中的URL,通过重定向传递格式信息

(编辑:李大同)

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

    推荐文章
      热点阅读