- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想简单地从 Controller 检查另一个 URL 是否被授权。
例如,我想像这样调用 Controller :
[HttpPost]
public ActionResult IsUrlAuthorized(string url)
{
bool isAuthorized = // What do I put here?
return Json(isAuthorized);
}
所以我想知道我可以调用什么来检查当前用户是否有权访问传入的 URL。我猜答案与路由有关,它位于 MVC 之外?
这是一个有点相似但又不完全相同的问题: ASP.NET MVC. Check if user is authorized from JavaScript
由于用户可能获得也可能未获得一般授权,但可能没有查看特定 URL 的正确权限或角色分配。
想法?
更新:我使用标准的 MVC 授权属性来锁定我的应用程序,所以我将在这里给出一个示例。在 MVC 中,路由映射到 Controller 。 Controller 上的单个方法可以限制为一个或多个角色:
public class HomeController : Controller
{
[Authorize(Roles = "User, Moderator")]
public ActionResult ListRecentPosts()
{
. . .
}
}
或者,可以将整个 Controller 限制为一个或多个角色:
[Authorize(Roles = "Admin")]
public class AdminController : Controller
. . .
任何这些 Controller 方法响应的实际 URL 都基于标准 MVC 应用程序中的默认映射:
routes.MapRoute("Default",
"{controller}/{action}/{id}",
new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);
但是,您可以对您的用户友好,并通过添加更多路由来使 URL 易于猜测 - 因此,一个 Controller 方法可以有许多指向它的名称。您不能仅从 URL 中假定并推断出 Controller 名称(即使它以这种方式映射了网站中一半的 URL)。
所以大概我需要一种方法直接询问路由引擎一个 URL 是否被当前用户授权,或者询问路由引擎哪个 Controller 和方法的两步,然后询问它们是否被授权 - 希望而不是通过直接使用反射和匹配角色,因为这又似乎承担了太多。
更新 2:出现这种情况的方式是我在我的应用程序顶部有一个帐户条。它的状态可以通过选择您被授权的多个帐户之一来更改。根据您在应用程序中的位置,您选择的帐户可能有权查看此页面 - 您可能正在填写您不想丢失的表格。因此,天真的方法 - 当他们选择另一个帐户时才刷新 - 是有害的,并且即使没有表格也浪费用户的时间,他们只是阅读一个全是文本的页面。
虽然这对用户来说很方便,但用户会公平地假设他们无法看到的页面,因为他们不应该拥有权限的用户确实被拒绝了(而且,将它们留在被禁止的页面 - 从中采取的操作将失败)。所以我需要知道是否根据他们的新权限重定向。
我喜欢 .Net 的其中一个原因是它的许多最好的库分解得很好,因此您可以轻松地重组属于其正常功能或新功能的一部分的东西。路由模块和 MVC 似乎都构建得很好,所以我不得不怀疑这是可以做到的。
廉价的 hack 是确保我的授权模块在用户未被授权时返回一致的重定向状态代码,并且当用户在帐户条中更改他们的帐户时,触发 2 个 AJAX 调用:一个更改帐户,和然后通过 AJAX 转到当前页面,只是为了检查 HTTP 状态代码。 200 OK 表示保留页面原样,Redirect 表示遵循重定向。显然这有点丑陋,涉及额外的 HTTP 调用,在日志中创建错误命中,并假设如何在应用程序中处理授权。
可能还有一个次要问题 - 页面可能已获得授权,但只是更改了它的工作方式或外观。这个特定的应用程序在外观上没有基于帐户的变化(除了帐户条本身),我可以通过提供表单监听的自定义事件来处理功能变化——它们可以从服务器重新加载任何相关数据以响应它。
最佳答案
仅当您仅使用 URL 授权时,才能使用 UrlAuthorization.CheckUrlAccessForPrincipal。但是对于使用路由的 MVC,我们强烈建议您不要使用 URL 授权来保护应用程序。
相反,我们建议在 Controller 类上使用授权属性。原因是可能有多个 URL 调用相同的 Controller 操作。最好在资源处保护资源,而不仅仅是在入口处。
在这种特殊情况下,您必须获得给定 URL 的 Controller 实例。这有点棘手,因为您基本上必须从拥有 URL 的点到拥有 Controller 的点运行 MVC 管道。这是可能的,但似乎很重量级。
我想知道是否有更好、更简单的方法来实现您的目标。你到底想做什么?
更新:根据您的情况,这听起来像是仅用于 UI 目的的初始检查。也许您需要做的就是向 URL 发出异步 Ajax 请求并检查 HTTP 状态代码。如果是 401 状态代码,则您知道该用户未获得授权。这似乎是最安全的选择。
关于asp.net-mvc - ASP.Net MVC : Check if URL is Authorized,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6480358/
我有一个我想暂时存储的对象。该对象现在在 Controller 中, Controller 将生成一个 View 。 AJAX 请求从 View 发送到下一个 Controller 。那一刻我需要先前
从MVC 2开始,我们可以轻松创建区域。现在,我的问题与嵌套区域(区域内部的区域)有关。 选择我的“father”区域文件夹,右键单击> Add> NO选项以获取new Area。 是否有可能以其他方
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我已经尝试了一些谷歌搜索和堆栈流搜索,但事实证明这比我想象的要难找到。我需要为我们的商店迁移到 ASP.NET MVC 2 的管理提供理由。最大的帮助将是任何企业级站点或使用 ASP.NET MVC
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我有一些常见的网页,它们将出现在多个 MVC 应用程序中。对于这些页面,我想在不同的 MVC 网站之间重用相同的源代码( Controller + View )。这样做的最佳方法是什么? ASP.NE
我正在使用 Spring MVC 来构建我的应用程序。 当用户在浏览器中运行应用程序时,我想显示一个默认的 jsp。我不想用 web.xml 中的标记。 我想我可以用 我已经创建了一个文件夹并添
我可能在这里分析过度了,但是根据我对 MVC 的阅读,似乎有很多关于如何做事情的观点。 是否有一个“最佳实践”网站或文档来定义 MVC 各个部分的职责? 请记住,我使用 EF/Repository&U
当杰里米和查德 posted about their FubuMvc project ,他们提到的差异化因素之一是他们的“雷霆穹顶校长”: The “Thunderdome Principle” –
我正在为 Spring MVC 应用程序实现缓存清除系统。 为了让这个系统正常工作,我必须从给定的 url 中删除“缓存破坏代码”。假设我生成的缓存破坏代码是“123”,我有一个 .css url:/
在调试 ASP.NET MVC 源时,我发现使用了“MVC-ControllerTypeCache.xml” 文件。但我无法理解这个文件的用途。我的意思是这个文件存储在哪里?asp.net MVc 如
我刚刚在我的本地机器上安装了 Visual Studio 11 和 MVC 4 beta。但是,每当我打开一个 MVC 3 项目(我想保留为 MVC 3)时,所有引用都已更新为版本 4 DLL。当然它
我有一个 MVC 3 应用程序,它具有一些核心功能(最重要的是自动化),但主要用作不同区域或模块的门户。我想将它组织到不同的模块中,只需稍作更改也可以部署为他们自己的网站。 该项目由论坛、博客引擎、用
我有自己的服务器,正在考虑将我的一个解决方案升级到 ASP.NET MVC 4,然后再升级其余的 (3+)。 作为其中的一部分,我下载了 the standalone installer对于 ASP.
构图 我有一个 MVC 项目,其中包含 C# 类,这些类最终通过 ajax 等进行序列化和使用。我使用 TypeLite 生成这些 C# 类的定义( here 讨论了 TypeLite 的替代方案),
我正在尝试了解现代 Web 应用程序架构。在 ASP.NET MVC 中,所有业务逻辑类都在 Model 中,Controller 接受并引导用户请求。如果我使用它,是否可以使用本身是 MVC 架构但
我有一个带有 OWIN 的 WebAPI 2 应用程序。现在我正在尝试向所有内容添加一个 MVC 5 Controller ,但没有找到我的 MVC 路由。我收到以下错误: No HTTP resou
在 MVC 3 中,他们添加了我一直在使用的依赖解析器。在回答某人对您发表评论的问题时,您应该使用 Ninject MVC 3 插件。 所以我的问题是为什么要使用它而不是内置的?如果这是要走的路,你如
我是 ASP.NET MVC 的新手,我正在寻找最不痛苦的方法来设置全局错误处理、日志记录和报告(通过电子邮件)。仅供引用,我的 ASP.NET MVC 应用程序在 Azure 中作为 Web 角色托
何时使用 MVC View 页面和 MVC View 内容页面?它们有什么区别? 最佳答案 **MVC View Page 用于创建页面,MVC VewP Content Page 用于创建页面并指定
我是一名优秀的程序员,十分优秀!