·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> OutputCache属性详解(三)— VaryByHeader,VaryByCustom
目录
OutputCache概念学习
OutputCache属性详解(一)
OutputCache属性详解(二)
OutputCache属性详解(三)
OutputCache属性详解(四)— SqlDependency
注意:设置 VaryByHeader 特性将启用在所有 HTTP 1.1 版缓存中缓存项,而不仅仅在 asp.net 缓存中进行缓存。用户控件中的 @ OutputCache 指令不支持此特性。
准备测试代码配置文件和页面如下:
<system.web> <caching> <outputCacheSettings> <outputCachePRofiles> <!--name 缓存配置名称 duration 缓存的时间(以秒计) enabled 指定缓存有效 --> <add name="outputCache60" duration="60" enabled="true" varyByParam="none" location="Any" varyByHeader="User-Agent"/> </outputCacheProfiles> </outputCacheSettings> </caching> <compilation debug="true"/> </system.web>
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><%@ OutputCache CacheProfile="outputCache60" %><html xmlns="http://www.w3.org/1999/xhtml"><head runat="server"> <title></title> <script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script></head><body> <form id="form1" runat="server"> <div> <%=DateTime.Now %> <br /> <asp:Label ID="lblTime" runat="server"></asp:Label> </div> <a href="Default2.aspx" >Default2.aspx</a> </form></body></html>
打开火狐和IE访问这个页面,我们可以看到火狐和IE下的HTTP请求头中的User-Agent不一致,如下:
则两个浏览器访问的结果也不一致,如下
我们修改参数,采用HttpHeader中的Host参数,如下:
<add name="outputCache60" duration="60" enabled="true" varyByParam="none" location="Any" varyByHeader="Host"/>
这两个浏览器的请求的HttpHeader中Host数据时一致的,浏览器数据结果也能保持一致:
测试使用谷歌,IE,火狐三种浏览器,这三种浏览器的Accept-Encoding如下:谷歌:Accept-Encoding:gzip,deflate,sdch
IE:Accept-Encodinggzip, deflate
火狐:Accept-Encoding gzip, deflate
修改配置文件如下:
<add name="outputCache60" duration="60" enabled="true" varyByParam="none" location="Any" varyByContentEncoding="sdch"/>
在三个浏览器中输入测试地址,刷新我们会发现 火狐和IE数据保持一致,读取缓存数据,而谷歌的数据则一直在变。
如果我们设置配置文件为:
<add name="outputCache60" duration="60" enabled="true" varyByParam="none" location="Any" varyByContentEncoding="sdch;gzip"/>
则三个浏览器的缓存都将会失效。
如果赋予该属性的值为 browser,缓存将随浏览器名称和主要版本信息的不同而异。如果输入自定义字符串,则必须在应用程序的 Global.asax 文件中重写 GetVaryByCustomString 方法。
<add name="outputCache60" duration="60" enabled="true" varyByParam="none" location="Any" varyByCustom="browser"/>
测试在两台机器上进行,一台机器火狐版本为32.0.1 IE8,另一台火狐版本为32.0.1 IE9,如下图所示,火狐的缓存数据保持一致,但IE的数据则不会一致(版本不一样)。
如果输入自定义字符串,则必须在应用程序的 Global.asax 文件中重写 GetVaryByCustomString 方法。如代码所示:
<add name="outputCache60" duration="60" enabled="true" varyByParam="none" location="Any" varyByCustom="UserHostName"/>
Global.asax文件新增如下:
public override string GetVaryByCustomString(HttpContext context, string custom) { if (string.Equals(custom, "UserHostName", StringComparison.OrdinalIgnoreCase)) { return Context.Request.UserHostName; } return base.GetVaryByCustomString(context, custom); }
如果我们将 varyByCustom="UserHostName" 代码去掉,那在多个客户端同时访问这个页面时,多个客户端所输出的内容都一致,但是采用varyByCustom="UserHostName" 这种自定义缓存模式,则每个客户端的缓存是按它们的请求的UserHostName 进行区分的,效果如下:
关于varyByCustom 推荐个论坛大家可以看下:http://bbs.csdn.net/topics/390667018
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><%@ OutputCache Duration="60" VaryByControl="slt_VaryByControl" %><html xmlns="http://www.w3.org/1999/xhtml"><head runat="server"> <title></title> <script src="Scripts/jquery-1.4.1.js" type="text/Javascript"></script></head><body> <form id="form1" runat="server"> <div> <%=DateTime.Now %> <br /> <asp:DropDownList ID="slt_VaryByControl" AutoPostBack="true" runat="server"> <asp:ListItem Text="测试数据1" Value="1"></asp:ListItem> <asp:ListItem Text="测试数据2" Value="2"></asp:ListItem> <asp:ListItem Text="测试数据3" Value="3"></asp:ListItem> </asp:DropDownList> </div> <a href="Default2.aspx">Default2.aspx</a> </form></body></html>
当我们切换slt_VaryByControl值时,缓存机制会根据所选的值来输出新的页面还是缓存页面。
VaryByHeader 、VaryByContentEncodings、VaryByCustom、VaryByControl 写到这,如有问题欢迎指正。
作者:释迦苦僧 出处:http://www.cnblogs.com/woxpp/p/3980851.html 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。