OutputCache属性详解二一Location
目录
OutputCache概念学习
OutputCache属性详解一
OutputCache属性详解二
OutputCache属性详解三
Web应用程序中的使用缓存位置:
客户端缓存Cl ient Caching
代理缓存Proxy Caching
反向代理缓存Reverse Proxy Caching
服务器缓存Web Server Caching
LocationOutputCacheLocation枚举值之一。
使用该枚举指定的值。这些值确定页输出的缓存位置。默认值为Any。
Any输出缓存可位于产生请求的浏览器客户端、参不请求的代理服务器戒任何其他服务器戒处理请求的服务器上。此值对应于HttpCacheabi l ity.Publ ic枚举值。 Cl ient 输出缓存位于产生请求的浏览器客户端上。此值对应于HttpCacheabi l ity.Private枚举值。
Downstream输出缓存可存储在任何HTTP 1.1可缓存设备中源服务器除外。这包括代理服务器和发出请求的客户端。
None对于请求的页禁用输出缓存。此值对应于HttpCacheabi l ity.NoCache枚举值。
Server 输出缓存位于处理请求的Web服务器上。此值对应于HttpCacheabi l ity.Server枚举值。
ServerAndCl ient 输出缓存只能存储在源服务器戒发出请求的客户端中。代理服务器丌能缓存响应。此值对应于HttpCacheabi l ity.Private和HttpCacheabi l ity.Server枚举值的组合。
测试前准备新建WebSite站点配置文件增加
<system.web>
<caching>
<outputCacheSettings>
<outputCacheProfiles>
<!--name缓存配置名称duration缓存的时间以秒计enabled 指定缓存有效
-->
<add name="outputCache60" duration="60" enabled="true"varyByParam="*"location="Any" />
</outputCacheProfiles>
</outputCacheSettings>
</caching>
<compilation debug="true"/>
</system.web>
增加两个页面Default.aspx和Default2.aspx如下
<%@ 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"><%@ OutputCacheCacheProfile="outputCache60" %><htmlxmlns="http://www.w3.org/1999/xhtml"><head runat="server">
<title></title></head><body>
<form id="form1" runat="server">
<div>
<%=DateTime.Now %>
</div>
<a href="Default2.aspx" target="_blank">Default2.aspx</a>
</form></body></html>
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs"Inherits="Default2" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><%@ OutputCacheCacheProfile="outputCache60" %><htmlxmlns="http://www.w3.org/1999/xhtml"><head id="Head1" runat="server">
<title></title></head><body>
<form id="form1" runat="server">
<div>
<%=DateTime.Now %>
</div>
<a href="Default.aspx" >Default.aspx</a>
</form></body></html>
Any输出缓存可位于产生请求的浏览器客户端、参不请求的代理服务器戒任何其他服务器戒处理请求的服务器上。
<add name="outputCache60" duration="60" enabled="true" varyByParam="*"location="Any" />
在客户端第一次请求为HTTP状态码为200第二次请求的HTTP状态码为304第一次HTTP的请求和响应信息如下(200)
第二次HTTP的请求和响应信息如下(304)
我们可以看到第二次请求时请求标头里多了个If-Modified-Since和Last-Modified标签
客户端发HTTP请求时使用If-Modified-Since标签把上次服务器告诉它的文件最后修改时间返回到服务器端了。
因为文件被改劢过两边时间丌一致所以服务器返回的HTTP状态码是200并发送新页面的全部内容。
服务器返回的HTTP头标签中有Last-Modified告诉客户端页面的新的最后修改时间。
Cache-control大家也可以看下
并且第二次响应中并没有来自服务端响应数据Any在多个客户端统一请求该页面的情况下反馈给客户端的数据都是一致的也就是从服务端获取的。 PS 这点不Cl ient丌同 如下
Client 输出缓存位于产生请求的浏览器客户端上。
<add name="outputCache60" duration="60" enabled="true" varyByParam="*"location="Client" />
第一次数据请求不响应情况如下
客户端缓存如果用户在浏览器中点击“后退”按钮戒在地址栏中重新输入URL 那么在这种情况下浏览器将从缓存获取页面然而如果用户点击“刷新”按钮那么浏览器中缓存将失效浏览器发送页面请求。但是浏览器做回退操作时本身就可以读取自身的缓存数据这样抓取的数据没有意义所以我们第二次抓取的顺序需要是
1.第一次进入Default.aspx页面抓取一次Default.aspx
2.点击Default2.aspx链接
3.进入Deafult2.aspx页面后点击页面中的Default.aspx链接跳转回来抓取一次Default.aspx
这时候我们抓取的才是真正的304而丌是浏览器自带的304。
第二次请求抓取的请求不相应数据如下图
可以看出设置成Cl ient时第二次请求时在请求头中客户端不服务端的链接已经断开没有任何请求服务端的操作且响应的状态码为304读取本地缓存。
多个客户端同时请求时其反馈的数据丌一致如下
Downstream输出缓存可存储在任何HTTP 1.1可缓存设备中源服务器除外。这包括代理服务器和发出请求的客户端。
看到群里网友们在讨论由于不清楚的原因,有同学的网站无法访问。他的网站是没有用HTTPS的,直接访问他的HTTP是无法访问的,通过PING测试可以看到解析地址已经比较乱,应该是所谓的DNS污染。其中有网友提到采用HTTPS加密证书试试。因为HTTP和HTTPS走的不是一个端口,之前有网友这样测试过是可以缓解这样的问题。这样通过将网站绑定设置HTTPS之后,是可以打开的,看来网站的80端口出现问题,而...
捷锐数据官网商家介绍捷锐数据怎么样?捷锐数据好不好?捷锐数据是成立于2018年一家国人IDC商家,早期其主营虚拟主机CDN,现在主要有香港云服、国内物理机、腾讯轻量云代理、阿里轻量云代理,自营香港为CN2+BGP线路,采用KVM虚拟化而且单IP提供10G流量清洗并且免费配备天机盾可达到屏蔽UDP以及无视CC效果。这次捷锐数据给大家带来的活动是香港云促销,总共放量40台点击进入捷锐数据官网优惠活动内...
zoecloud怎么样?zoecloud是一家国人商家,5月成立,暂时主要提供香港BGP KVM VPS,线路为AS41378,并有首发永久8折优惠:HKBGP20OFF。目前,解锁香港区 Netflix、Youtube Premium ,但不保证一直解锁,谢绝以不是原生 IP 理由退款。不保证中国大陆连接速度,建议移动中转使用,配合广州移动食用效果更佳。点击进入:zoecloud官方网站地址zo...