zoukankan      html  css  js  c++  java
  • 根据自定义字符串来缓存(部分)页面

    比如说网站有一个Header.ascx用户控件,每个页面都调用此控件作为"页面头部",直接可以缓存此用户控件就可以提交性能,不过,现在此Header.ascx用户控件要显示登陆用户的登陆名,所以,就不能直接用下面这种缓存方式:

    <% @ OutputCache Duration = " 86400 "  VaryByParam = " None "   %>

    这个时候就可以利用"根据自定义字符串来缓存页"这种方法了,具体如下:

    <%@ OutputCache Duration="86400" VaryByParam="None" VaryByCustom="HeaderPageKey" %>

    然后在Global类里面重写方法 GetVaryByCustomString

            public override string GetVaryByCustomString(HttpContext context, string custom)
            {
                
    if(custom=="HeaderPageKey")
                {
                    
    //缓存 Header.ascx 控件
                    if(context.Request.IsAuthenticated)
                    {
                        
    return context.User.Identity.Name;
                    }
                    
    else
                    {
                        
    return "NoAuthenticated_User";
                    }
                }
                
    return base.GetVaryByCustomString (context, custom);
            }

    用户如果没有登陆,那么缓存一个版本,如果已经登陆,那么根据登陆名的不同缓存另外一个版本,哈哈,为每个用户都缓存了一个版本,这样做,应该说不是很好的解决方法。

    上述缓存技术可以参考 http://msdn.microsoft.com/library/chs/default.asp?url=/library/CHS/cpguide/html/cpconcachingversionsofpagebasedonparameters.asp

    另外,MSPetShop3.0里面也用到了这样的缓存方法,根据Request.Querystring以及是否登陆来缓存不同的版本,不过,这个缓存好像默认没有开启。
  • 相关阅读:
    VUE 入门基础(2)
    VUE 入门基础(1)
    常用正则表达式
    git 常用命令
    JavaScript 常用算法
    SVG 使用
    移动前端头部标签(HTML5 meta)
    开发常用小demo 整理
    Reactjs 入门基础(三)
    Reactjs 入门基础(二)
  • 原文地址:https://www.cnblogs.com/caca/p/358921.html
Copyright © 2011-2022 走看看