asp.net-mvc C 防止在ASP.NET MVC中缓存属性,每次执行一个Action时强制执行属性
发布时间:2023-12-21 16:57:55 所属栏目:asp.Net 来源:DaWei
导读: 根据各种文章(例如
here和
here),可以缓存ASP.NET MVC操作的属性结果,并且在调用控制器操作时不再执行.
在我的情况下,这种行为是不可取的(例如,我有一个基于我自己的属性和IP的授权
here和
here),可以缓存ASP.NET MVC操作的属性结果,并且在调用控制器操作时不再执行.
在我的情况下,这种行为是不可取的(例如,我有一个基于我自己的属性和IP的授权
|
根据各种文章(例如 here和 here),可以缓存ASP.NET MVC操作的属性结果,并且在调用控制器操作时不再执行. 在我的情况下,这种行为是不可取的(例如,我有一个基于我自己的属性和IP的授权系统,每次都需要执行的角色检查,以及其他事情). 如何阻止ASP.NET MVC缓存我的属性/属性执行结果并保证每次都执行它们? 解决方法 查看AuthorizeAttribute的源代码(在Codeplex上或通过Reflector),了解如何关闭授权页面的缓存.我将它重构为我的自定义授权属性的单独方法,该属性派生自AuthorizeAttribute. protected void CacheValidateHandler( HttpContext context,object data,ref HttpValidationStatus validationStatus ) { validationStatus = OnCacheAuthorization( new HttpContextWrapper( context ) ); } protected void SetCachePolicy( AuthorizationContext filterContext ) { // ** IMPORTANT ** // Since we're performing authorization at the action level,the authorization code runs // after the output caching module. In the worst case this could allow an authorized user // to cause the page to be cached,then an unauthorized user would later be served the // cached page. We work around this by telling proxies not to cache the sensitive page,// then we hook our custom authorization code into the caching mechanism so that we have // the final say on whether a page should be served from the cache. HttpCachePolicyBase cachePolicy = filterContext.HttpContext.Response.Cache; cachePolicy.SetProxyMaxAge( new TimeSpan( 0 ) ); cachePolicy.AddValidationCallback( CacheValidateHandler,null /* data */); }(编辑:吉安站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net-mvc – 在ASP.NET MVC中的LinkButton
- asp.net-web-api C ASP身份OAuth令牌 C 我应该在移动应用流
- asp.net – 是否可以根据用户角色隐藏/显示Kendo网格列?
- asp.net汉字转拼音和获取汉字首字母的代码
- asp.net-mvc-4 – 在哪里可以找到WebMatrix.WebData.WebSec
- iis-7 C ASP 3.0应用程序对象
- .net – ReportViewer 2010无法评估表达式
- WPAD查询从ASP.NET调用webservice
- 如何在asp.net中更改javascript警告框的标题?
- asp.net – 通过邮件发送wcf服务消费表单数据
推荐文章
站长推荐
- asp.net-mvc – ASP.NET MVC现在是“开源”.这是
- asp.net-mvc C 如何设置AntiForgeryToken cookie
- 在使用ASP.NET会话时是否可以强制请求并发?
- asp.net C Umbraco CMS(.NET):加载xslt /用户控
- asp.net C 如何使用javascript生成假回发?
- asp.net-mvc – ASP.NET捆绑/分类:包括动态生成
- asp.net-mvc – Visual Studio 2010 Full和ASP.N
- asp.net-mvc – 如何在我自己的自定义助手中使用
- asp.net-mvc-3 – 将数组传递给RouteValues,并将
- asp.net-mvc-3 – 用于在ASP.NET MVC3中使用Grid
热点阅读
- asp.net-core C 如何使用ASP.NET注册OData
- asp.net C MVC4 C ContextDependentView C
- asp.net-mvc-3 C 如何从ASP.NET MVC#输出中
- asp.net-mvc C 已经使用相同的参数类型定义
- asp.net-mvc C 使用AD的ASP.NET MVC表单Aut
- ASP.Net C AJAX UpdatePanel中的Javascript
- asp.net-mvc C ASP.NET MVC中的WebApi [Fro
- asp.net C 适用于多个用户的EWS通知中心
- asp.net-mvc C 未在ELMAH中记录的错误
- asp.net-mvc C MVC应用程序中的随机数生成
