HttpContext.Current.Cache和HttpContext.Response.Cache有什么区别?

时间:2013-01-31 09:42:23

标签: c# asp.net-mvc asp.net-mvc-3 caching

想知道 - HttpContext.Response.CacheHttpContext.Current.Cache对象之间有什么不同?什么应该在Asp.net MVC Web应用程序中使用?

为什么我问这个问题?

因为,我有自己的[NoCache]属性,它负责在视图重定向期间避免缓存。

E.g。

public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        var cache = filterContext.HttpContext.Response.Cache;
        cache.SetExpires(DateTime.Now.AddDays(-1));
        cache.SetValidUntilExpires(false);
        cache.SetRevalidation(HttpCacheRevalidation.AllCaches);
        cache.SetCacheability(HttpCacheability.NoCache);
        cache.SetNoStore();
        base.OnActionExecuting(filterContext);
    }

我在BaseController中使用了以上属性,比如..

[NoCache]
public class BaseController : Controller
{

}

这很好用!

但是,在认证部分 - 我通过以下机制将一些信息存储在缓存中

public ActionResult Login()
{
    HttpContext.Current.Cache.Insert("someKey", "someValue", null, expiredTime.Value, Cache.NoSlidingExpiration);
    return view();
}

所以,我的问题是......

我在控制器的基类中使用我的自定义属性,它负责清除缓存项,即使我仍然可以访问整个应用程序中的缓存键和值,这是由Login方法代码设置的。< / p>

为什么这两种缓存机制的行为都不同?这两者有什么区别?

请您就此提出一些想法或信息。

1 个答案:

答案 0 :(得分:10)

HttpContext.Current.Cache是一个提供任何类型的可序列化对象的缓存的类。它本身等同于HttpRuntime.Cache,使你的水更加泥泞。

我们通常使用HttpContext.Current.Cache来缓存数据库服务器中的数据。这节省了不得不不断向数据库询问变化不大的数据。这完全是服务器端的,不会影响客户端。

HttpResponse.Cache允许您设置和控制随响应内容一起发送的各种缓存控制标头。这告诉客户端(以及任何中间代理)您建议使用哪种缓存。注意我说建议,因为无论客户是否尊重它都是完全随意的。