隨筆 - 0, 文章 - 264, 評論 - 170, 引用 - 0
          數(shù)據(jù)加載中……

          http返回頭中content-length與Transfer-Encoding: chunked的問題釋疑

          先說說問題出現(xiàn)的背景:
                  公司服務(wù)器與手機客戶端交互,客戶端請求一個動態(tài)生成的XML文件,在用firebug查看http響應(yīng)頭的時候,有時候發(fā)現(xiàn)有content-length屬性,有時候沒有這個屬性,取而代之的是Transfer-Encoding: chunked屬性。由于客戶端強制要求,服務(wù)器端必須返回content-length,否則,客戶端將不予解析。于是測試發(fā)現(xiàn),當XML文件很小的時候,是有content-length屬性的,到達一個值時,就成了Tansfer-Encoding:chunked。

          再引用一段話,解釋一下Transfer-Encoding:chunked這個屬性的意義:
                  通常,HTTP協(xié)議中使用Content-Length這個頭來告知數(shù)據(jù)的長度。然后,在數(shù)據(jù)下行的過程中,Content-Length的方式要預(yù)先在服務(wù)器中緩存所有數(shù)據(jù),然后所有數(shù)據(jù)再一股腦兒地發(fā)給客戶端。
              如果要一邊產(chǎn)生數(shù)據(jù),一邊發(fā)給客戶端,WEB 服務(wù)器就需要使用"Transfer-Encoding: chunked"這樣的方式來代替Content-Length。

          最后說說自己的理解與解決方式:
                  通過種種跡象,我得出的結(jié)論是,JSP頁面有一個緩存大小,當輸出數(shù)據(jù)的長度沒有到達這個大小的時候,服務(wù)器是知道總的數(shù)據(jù)長度的,所以服務(wù)器會輸出content-length頭。但如果超過緩存大小,那么,緩存一滿,服務(wù)器就得輸出內(nèi)容給客戶端,所以,不能判斷整個內(nèi)容的大小,于是返回Transfer-Encoding:chunked這個頭信息。
                  解決方式是:在JSP頁面中加入代碼,response.setBufferSize(402800);40820即400K,其實只要這個值大于你返回的數(shù)據(jù)的大小就行了。具體設(shè)置多少,你可以根據(jù)實際情況,合理配置。另外說一句,在page指令中加入buffer="400kb",是不管用的,我測試的情況是這樣。

          posted on 2010-10-28 12:48 小一敗涂地 閱讀(30843) 評論(0)  編輯  收藏 所屬分類: http相關(guān)

          主站蜘蛛池模板: 英山县| 久治县| 凯里市| 临清市| 盐源县| 香港 | 宜城市| 繁峙县| 天全县| 缙云县| 澄城县| 杭州市| 西昌市| 临沧市| 本溪| 庆安县| 马龙县| 高雄市| 西乌珠穆沁旗| 屏南县| 五大连池市| 平塘县| 宾川县| 黔西县| 宜城市| 宿州市| 石家庄市| 木里| 天峨县| 汶上县| 科尔| 亳州市| 林甸县| 临漳县| 铅山县| 祥云县| 沙田区| 贺州市| 五家渠市| 岑巩县| 工布江达县|