emu in blogjava

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            171 隨筆 :: 103 文章 :: 1052 評論 :: 2 Trackbacks

          http://www.aygfsteel.com/emu/archive/2011/02/27/345262.html
            
                這個問題不是太廣為人知,但也算不上新鮮知識了,IE6如果接收到一個gzip壓縮的http響應(yīng),那么這個響應(yīng)中的Etag信息會被拋棄,此時只能依賴last-modified時間來設(shè)計cache策略。某些類型的Vary值據(jù)說也會導(dǎo)致相同的問題。
                  為了這個問題emu在http頭上動了n多手術(shù),甚至把200響應(yīng)狀態(tài)硬生生換成206等狀態(tài),IE6一直都非常頑固的不肯吐出If-None-Match信息。幾乎要放棄了。
                  丟開這個bug,我們來看問題的實質(zhì)是什么。實質(zhì)是,我們有一個叫做Etag的,響應(yīng)內(nèi)容的一個hash值,需要在響應(yīng)的時候從服務(wù)器送給瀏覽器,并且要求在瀏覽器下次請求同一個路徑的時候把這個hash值送回給服務(wù)器校驗。http中規(guī)定了,我們可以在http header內(nèi)容中通過一個叫做Etag的header來做這個事,但是現(xiàn)在瀏覽器不給力啊,有啥別的手段可以做相同的事情呢?

                  答案一點也不難想,我們一天到晚在實現(xiàn)“把一個值從服務(wù)器送給瀏覽器,并讓瀏覽器吧它送回服務(wù)器”這件事的時候都是用什么手段的呢?沒錯啦,就是cookie。而且cookie還支持path!
                  因此需要做的事情就是,server在發(fā)現(xiàn)User-Agent是IE6的時候,在返回gzip內(nèi)容的時候出了要送Last-Modified時間之外,不要送Etag頭了,改為返回一個set-cookie頭:
                  Set-Cookie: etag=hash; pagh=/mypath
                  服務(wù)器在下次收到請求的時候,如果收到了If-Modified-Since信息,表明客戶端有一份當(dāng)前請求的cache,就可以從cookie里面驗證etag值來決定是否返回304拉!
          posted on 2011-02-27 00:37 emu 閱讀(3447) 評論(8)  編輯  收藏

          評論

          # re: IE6上Gzip+Etag問題的解決方案[未登錄] 2011-03-02 22:35 ryan
          If-Modified-Since不就已經(jīng)可以判斷這個請求是否需要下發(fā)304還是原本的文件的么?

          為什么還需要額外的模擬etag的工作方式呢?  回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案 2011-03-14 14:09 煤矸石粉碎機(jī)
          不錯,過來學(xué)習(xí)了  回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案 2011-03-21 10:45 emu
          @ryan

          http://developer.yahoo.com/performance/rules.html
          ETags were added to provide a mechanism for validating entities that is more flexible than the last-modified date.
          有不同的應(yīng)用場景的。
            回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案[未登錄] 2011-04-02 10:06 小海
          簡單明了,樓主寫得很好哈~~~  回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案 2011-05-04 11:10 http://ask.zhongguoren.me
          感謝`~~來學(xué)習(xí)了~~  回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案 2011-05-04 11:13 移動破碎站
          寫的不錯,還是我朋友介紹我來看的·  回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案[未登錄] 2011-05-08 18:00 1
          寫的很好. http://www.7004054.com 期待您的回訪.  回復(fù)  更多評論
            

          # re: IE6上Gzip+Etag問題的解決方案[未登錄] 2012-02-05 10:55 ryan
          @emu

          etag字符串的最后一部分整合了機(jī)器信息,
          Entity tags (ETags) are a mechanism that web servers and browsers use to determine whether the component in the browser's cache matches the one on the origin server.

          但這個在CDN部署上,恰恰是最不適宜帶上的。 所以如果要保證來自統(tǒng)一服務(wù)器,那么Etag建議帶上,如果CDN多地域機(jī)器部署,這個Etag就不合適了,至少要把機(jī)器信息干掉,所以直接用If-Modified-Since 更為合適吧  回復(fù)  更多評論
            


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 松溪县| 平原县| 安多县| 界首市| 依安县| 冷水江市| 怀远县| 津南区| 抚宁县| 庐江县| 射阳县| 上饶县| 建宁县| 遵义市| 泰安市| 如皋市| 巴马| 临潭县| 望谟县| 荆州市| 南安市| 壤塘县| 巢湖市| 柏乡县| 台山市| 彭泽县| 手游| 日照市| 晴隆县| 区。| 石首市| 安多县| 阜新| 营口市| 泰州市| 民权县| 东平县| 颍上县| 黄山市| 辽宁省| 卓尼县|