• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見(jiàn)諒!~
            隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            HTTP/1.1 Cache-Control的理解

                 網(wǎng)頁(yè)的緩存是由HTTP消息頭中的“Cache-control”來(lái)控制的,常見(jiàn)的取值有privateno-cachemax-agemust-revalidate等,默認(rèn)為private。其作用根據(jù)不同的重新瀏覽方式分為以下幾種情況:
            1) 打開(kāi)新窗口
            如果指定cache-control的值為privateno-cachemust-revalidate,那么打開(kāi)新窗口訪問(wèn)時(shí)都會(huì)重新訪問(wèn)服務(wù)器。而如果指定了max-age值,那么在此值內(nèi)的時(shí)間里就不會(huì)重新訪問(wèn)服務(wù)器,例如:
            Cache-control: max-age=5
            表示當(dāng)訪問(wèn)此網(wǎng)頁(yè)后的5秒內(nèi)再次訪問(wèn)不會(huì)去服務(wù)器
            2) 在地址欄回車
            如果值為privatemust-revalidate(和網(wǎng)上說(shuō)的不一樣),則只有第一次訪問(wèn)時(shí)會(huì)訪問(wèn)服務(wù)器,以后就不再訪問(wèn)。如果值為no-cache,那么每次都會(huì)訪問(wèn)。如果值為max-age,則在過(guò)期之前不會(huì)重復(fù)訪問(wèn)。
            3) 按后退按扭
            如果值為privatemust-revalidatemax-age,則不會(huì)重訪問(wèn),而如果為no-cache,則每次都重復(fù)訪問(wèn)
            4) 按刷新按扭
            無(wú)論為何值,都會(huì)重復(fù)訪問(wèn)
            clip_image001

            項(xiàng)目中使用過(guò)濾器來(lái)設(shè)置網(wǎng)頁(yè)的緩存

            clip_image002FilterConfig fc;
            clip_image002
            clip_image002   
            public void doFilter(ServletRequest req, ServletResponse res,
            clip_image003clip_image004            FilterChain chain)
            throws IOException, ServletException clip_image005{
            clip_image006        HttpServletResponse response = (HttpServletResponse) res;
            clip_image006       
            // set the provided HTTP response parameters
            clip_image007clip_image008
                    for (Enumeration e = fc.getInitParameterNames(); e.hasMoreElements();) clip_image005{
            clip_image006            String headerName = (String) e.nextElement();
            clip_image006            response.addHeader(headerName, fc.getInitParameter(headerName));
            clip_image009        }
            clip_image006       
            // pass the request/response on
            clip_image006
                    chain.doFilter(req, response);
            clip_image010    }


            配置文件的配置:

            clip_image002<filter>
            clip_image002       
            <filter-name>NoCache</filter-name>
            clip_image002       
            <filter-class>filter.CacheFilter</filter-class>
            clip_image002       
            <init-param>
            clip_image002           
            <param-name>Cache-Control</param-name>
            clip_image002           
            <param-value>no-cache, must-revalidate</param-value>
            clip_image002       
            </init-param>
            clip_image002   
            </filter>
            clip_image002   
            <filter>
            clip_image002       
            <filter-name>CacheForWeek</filter-name>
            clip_image002       
            <filter-class>filter.CacheFilter</filter-class>
            clip_image002       
            <init-param>
            clip_image002           
            <param-name>Cache-Control</param-name>
            clip_image002           
            <param-value>max-age=604800</param-value>
            clip_image002       
            </init-param>
            clip_image002   
            </filter>
            clip_image002
            clip_image002   
            <filter-mapping>
            clip_image002       
            <filter-name>CacheForWeek</filter-name>
            clip_image002       
            <url-pattern>*.js</url-pattern>
            clip_image002   
            </filter-mapping>
            clip_image002   
            <filter-mapping>
            clip_image002       
            <filter-name>CacheForWeek</filter-name>
            clip_image002       
            <url-pattern>*.css</url-pattern>
            clip_image002   
            </filter-mapping> 
            clip_image002   
            <filter-mapping>
            clip_image002       
            <filter-name>CacheForWeek</filter-name>
            clip_image002       
            <url-pattern>*.gif</url-pattern>
            clip_image002   
            </filter-mapping> 


            上述設(shè)置保存了1周的緩存。

            posted on 2009-09-10 11:48 肥仔 閱讀(1560) 評(píng)論(0)  編輯 收藏 引用 所屬分類: HTTP & URL

            久久久久香蕉视频| 99久久国产精品免费一区二区| 国产激情久久久久影院| 国产精品99久久不卡| 一本综合久久国产二区| 久久亚洲春色中文字幕久久久| 亚洲国产精品久久久久婷婷软件| 人妻少妇精品久久| 97久久久精品综合88久久| 亚洲国产成人精品女人久久久 | 狠狠色丁香婷婷综合久久来来去| 久久青青草原精品国产软件| 久久久噜噜噜www成人网| 久久精品国产色蜜蜜麻豆| 伊人久久精品无码av一区| 久久精品无码一区二区三区日韩| 国内精品久久久久久99| 伊人久久大香线蕉综合热线| 91精品国产色综久久| 久久人人妻人人爽人人爽| 国产精品成人久久久| 久久综合五月丁香久久激情| 国产一久久香蕉国产线看观看| 国产成人精品综合久久久久| 久久综合精品国产一区二区三区| 久久精品这里热有精品| 成人国内精品久久久久一区| 无码日韩人妻精品久久蜜桃 | 亚洲欧洲中文日韩久久AV乱码| 狠狠色丁香久久婷婷综| 麻豆亚洲AV永久无码精品久久 | 性欧美大战久久久久久久| 国产精品日韩欧美久久综合| 国产日产久久高清欧美一区| 99久久精品日本一区二区免费| 中文精品久久久久人妻不卡| 精品国产乱码久久久久软件| 久久受www免费人成_看片中文| 久久久久亚洲国产| 久久久久99这里有精品10| 久久婷婷国产剧情内射白浆|