好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁(yè) > 知識(shí)庫(kù) > JSP對(duì)URL鏈接中的中文亂碼處理方法總結(jié)

JSP對(duì)URL鏈接中的中文亂碼處理方法總結(jié)

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

IE缺省對(duì)URL后面的參數(shù)是不編碼發(fā)送的,但是Tomat缺省是按ISO8859-1來(lái)進(jìn)行URL編碼的,因此才會(huì)出錯(cuò)。

方法一:

對(duì)URL鏈接進(jìn)行二次編碼:

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

或者單獨(dú)對(duì)參數(shù)進(jìn)行二次編碼:

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");
//這句話一定要寫,因?yàn)槿绻粚懙脑捑幋a就是%E5%A6%88%
code_type = java.net.URLDecoder.decode(code_type,"UTF-8");

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

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

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

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

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

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

簡(jiǎn)單來(lái)說(shuō),就是Tomcat服務(wù)器會(huì)自動(dòng)幫你做一次URLDecode,再加上你自己在Service代碼里面寫的URLDecode,一共就是兩個(gè)Decode了。既然要兩次Decode,當(dāng)然就需要兩次Encode了。或許你會(huì)問(wèn),干脆只Encode一次,然后在java代碼里不Decode,呵呵,這個(gè)也是不行的,這其實(shí)也就是為什么要進(jìn)行兩次Encode的原因吧。

方法二:(經(jīng)測(cè)試不支持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")%>">點(diǎn)擊這里/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中設(shè)置server.xml中的Connector熟悉URIEncoding="UTF-8",確保解碼格式與編碼格式統(tǒng)一。

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

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

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