Posted on 2008-07-16 10:31
寒武紀(jì) 閱讀(5207)
評(píng)論(2) 編輯 收藏 所屬分類:
Java
最近一個(gè)程序出了點(diǎn)問題,對(duì)于中文參數(shù)的GET請(qǐng)求,服務(wù)器無法解析出正確的參數(shù)。剛好服務(wù)器的那端是另一個(gè)項(xiàng)目組負(fù)責(zé),是異構(gòu)系統(tǒng),當(dāng)初測(cè)試的時(shí)候也是走流程化,涉及到很多工作上的協(xié)調(diào)就比較麻煩,測(cè)試也不充分,像趕鴨子上架一樣就上線了,催說是項(xiàng)目緊急。當(dāng)然這是話外,不多廢話。
httpClient的GetMethod類加入?yún)?shù)的方法是如下:
跟蹤一下httpClient的GetMethod的源代碼,繼承自HttpMethodBase,源碼如下:

public void setQueryString(String queryString)
{
this.queryString = queryString;
}

public void setQueryString(NameValuePair[] params)
{
LOG.trace("enter HttpMethodBase.setQueryString(NameValuePair[])");
queryString = EncodingUtil.formUrlEncode(params, "UTF-8");
}
EncodingUtil是httpClient定義的一個(gè)編碼工具類,由于默認(rèn)設(shè)置的是UTF-8,所以對(duì)于一些系統(tǒng)可能就無法識(shí)別。可以在外部這樣更改:
method.setQueryString(EncodingUtil.formUrlEncode(pair, "GB2312"));另外,
注意請(qǐng)求頭也要修改為對(duì)應(yīng)的一致編碼方式,method.addRequestHeader("Content-type" , "text/html; charset=GB2312");如果這二個(gè)編碼不一致,就會(huì)引起亂碼。
剛開始的時(shí)候嘗試過都使用一致的UTF-8,但是發(fā)現(xiàn)還是亂碼,這應(yīng)該是服務(wù)器的原因。IE默認(rèn)的就是采用操作系統(tǒng)Windows的中文編碼去進(jìn)行Encoder的,服務(wù)器原先基本上都為IE服務(wù)的,所以改為GB2312就能正常識(shí)別得到。
另外,上面提到的EncodingUtil這個(gè)工具是從apache的另一個(gè)組件codec包裝而來的,而非SUN的URLEncoder。有興趣的可以研讀一下源代碼。
剛進(jìn)場(chǎng)的時(shí)候戲就落幕