主頁 > 知識庫 > JSP對URL鏈接中的中文亂碼處理方法總結

JSP對URL鏈接中的中文亂碼處理方法總結

熱門標簽:聊城智能電銷機器人外呼 泰州泰興400電話 怎么申請 南京新思維電話機器人 好操作的電話機器人廠家 企業(yè)怎么在聯(lián)通申請400電話 地圖標注市場怎么樣 南昌市地圖標注app 如何用中國地圖標注數(shù)字點 百度地圖添加標注圖標樣式

IE缺省對URL后面的參數(shù)是不編碼發(fā)送的,但是Tomat缺省是按ISO8859-1來進行URL編碼的,因此才會出錯。

方法一:

對URL鏈接進行二次編碼:

a onclick="javascript:window.open(encodeURI(encodeURI('./DispatchAction.do?efFormEname=FKRY0001code_type=中文參數(shù)')))">測試/a>

或者單獨對參數(shù)進行二次編碼:

var code_type = "中文參數(shù)";
code_type = encodeURI(code_type); 
code_type = encodeURI(code_type);
window.open("./DispatchAction.do?efFormEname=FKRY0001code_type="+code_type);
Service:
String code_type = request.getParameter("code_type");
//這句話一定要寫,因為如果不寫的話編碼就是%E5%A6%88%
code_type = java.net.URLDecoder.decode(code_type,"UTF-8");

有人提出為什么要在客戶端對字符串重復編碼兩次呢?

如果因為項目需要,不能指定容器使用何種編碼規(guī)則來解碼提交的參數(shù),比如:需要接收來自不同頁面,不地編碼的參數(shù)內(nèi)容時。 (又或者是開發(fā)人員被這有點復雜的東西搞得暈頭轉(zhuǎn)向,不懂得如何正確的去做好這接收參數(shù)的工作)

這個時候,在客戶端對參數(shù)進行二次編碼,可以有效的避開“提交多字節(jié)字符”的這個棘手問題。

因為第一次編碼,你的參數(shù)內(nèi)容便不帶有多字節(jié)字符了,成了純粹的 Ascii 字符串。(這里把編第一次的結果叫成 [STR_ENC1] 好了。[STR_ENC1] 是不帶有多字節(jié)字符的)

再編一次后,提交,接收時容器自動解一次(容器自動解的這一次,不管是按 GBK 還是 UTF-8 還是 ISO-8859-1 都好,都能夠正確的得到 [STR_ENC1])

然后,再在程序中實現(xiàn)一次 decodeURIComponent (Java中通常使用 java.net.URLDecoder.decode(***, "UTF-8"))就可以得到想提交的參數(shù)的原值。

簡單來說,就是Tomcat服務器會自動幫你做一次URLDecode,再加上你自己在Service代碼里面寫的URLDecode,一共就是兩個Decode了。既然要兩次Decode,當然就需要兩次Encode了?;蛟S你會問,干脆只Encode一次,然后在java代碼里不Decode,呵呵,這個也是不行的,這其實也就是為什么要進行兩次Encode的原因吧。

方法二:(經(jīng)測試不支持IE8)

http://xxx.do?ptname=中文參數(shù)
String strPtname = request.getParameter("ptname");
strPtname = new String(strPtname.getBytes("ISO-8859-1"), "UTF-8");

方法三:

%@ page contentType="text/html;charset=gb2312" %>
a href="ds.jsp?url=%=java.net.URLEncoder.encode("編碼的是這里","GB2312")%>">點擊這里/a>
%
//request.setCharacterEncoding("GBK");
if(request.getParameter("url")!=null)
{
str=request.getParameter("url");
str=java.net.URLDecoder.decode(str,"GB2312");
str=new String(str.getBytes("ISO-8859-1"));
out.print(str);
}
%>

方法四:
Tomcat中設置server.xml中的Connector熟悉URIEncoding="UTF-8",確保解碼格式與編碼格式統(tǒng)一。

您可能感興趣的文章:
  • jsp用過濾器解決中文亂碼問題的方法
  • JSP利用過濾器解決request中文亂碼問題
  • JSP頁面中超鏈接傳遞中文參數(shù)出現(xiàn)亂碼問題解決方法
  • JSP中文亂碼常見3個例子及其解決方法
  • 分享JSP中文亂碼解決方法
  • JSP頁面?zhèn)鲄⒊霈F(xiàn)中文亂碼的解決方案
  • jsp之間傳參數(shù)接受中文有亂碼問題解決方法
  • jsp地址欄傳中文顯示亂碼解決方法分享
  • JSP出現(xiàn)中文亂碼問題解決方法詳解

標簽:白銀 烏蘭察布 臨汾 銅川 吉林 自貢 山南 開封

巨人網(wǎng)絡通訊聲明:本文標題《JSP對URL鏈接中的中文亂碼處理方法總結》,本文關鍵詞  JSP,對,URL,鏈接,中的,中文,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《JSP對URL鏈接中的中文亂碼處理方法總結》相關的同類信息!
  • 本頁收集關于JSP對URL鏈接中的中文亂碼處理方法總結的相關信息資訊供網(wǎng)民參考!
  • 推薦文章