• ASP.NET 客户端缓存


    #region 客户端缓存
            /// <summary>
            /// 设置客户端缓存文件
            /// </summary>
            /// <param name="lastModified">最后被修改的时间</param>
          
            private void SetClientCaching(DateTime lastModified)
            {
                Response.Cache.SetETag(lastModified.Ticks.ToString());
                Response.Cache.SetLastModified(lastModified);
                //public 以指定响应能由客户端和共享(代理)缓存进行缓存。
                Response.Cache.SetCacheability(HttpCacheability.Public);
                //是允许文档在被视为陈旧之前存在的最长绝对时间。
                Response.Cache.SetMaxAge(new TimeSpan(7, 0, 0, 0));
                //可调过期策略
                Response.Cache.SetSlidingExpiration(true);
            }
            private void SetClientCache()
            {
                //默认缓存的秒数
                int secondsTime = 100;
                //判断最后修改时间是否在要求的时间内
                //如果服务器端的文件没有被修改过,则返回状态是304,内容为空,这样就节省了传输数据量。如果服务器端的文件被修改过,则返回和第一次请求时类似。
                if (Request.Headers["If-Modified-Since"] != null && TimeSpan.FromTicks(DateTime.Now.Ticks - DateTime.Parse(Request.Headers["If-Modified-Since"]).Ticks).Seconds < secondsTime)
                {
                    //测试代码,在这里会发现,当浏览器返回304状态时,下面的日期并不会输出
                    Response.Write(DateTime.Now);
                    Response.StatusCode = 304;
                    //Response.HeaderEncoding.add("Content-Encoding", "gzip");
                    Response.StatusDescription = "Not Modified";
                }
                else
                {
                    //输出当前时间
                    Response.Write(DateTime.Now);

                    //设置客户端缓存状态
                    SetClientCaching( DateTime.Now);
                }
            }
            #endregion

  • 相关阅读:
    【剑指offer】和为S的连续整数序列
    【剑指offer】连续子数组最大和
    【剑指offer】从尾到头打印链表
    【Spark】概述
    【剑指offer】题目20 顺时针打印矩阵
    【剑指offer】题目36 数组中的逆序对
    【C语言】二维数组做形参
    【剑指offer】题目38 数字在排序数组中出现的次数
    SAP 锁对象 基本概念与基本操作 SE11
    线程特定数据TSD总结
  • 原文地址:https://www.cnblogs.com/rainnight/p/1111352.html
Copyright © 2020-2023  润新知