DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX詳解 >> AJAX POST提交中文亂碼解決(jsp)
AJAX POST提交中文亂碼解決(jsp)
編輯:AJAX詳解     

今天終於解決了AJax的中文亂碼問題,寫篇文章來幫助一下有同樣問題的朋友們。我的開發環境:XP, eclipse,使用GB18030編碼。

當遇到這個問題時,到網上去查了好多文章,提到幾種解決方案,如:全站UTF-8編碼;請求頭編碼為中文;使用Javascript中的escape函數。

使用GET方式提交數據的時候,中文問題很好解決,setrequestheader("Content-Type","text/Html; encoding=gb18030")就可以了。但這個方法在POST方式中卻不起作用。大家都知道GET方式提交數據有長度限制,有時我們必須使用POST方式來提交數據。

但對於POST方式,使用上述的幾種方法經過多次測試,問題依舊。我郁悶了好幾天。

今天把問題解決了,很簡單,是使用escape(或encodeURI,兩個函數Javascript的函數,功能基本相同,可以查一下相關的幫助),但要使用兩次,這是解決問題的關鍵。

我的例子涉及兩個頁面,一個是初始頁面,一個是AJax請求處理頁面。

初始頁面內容如下(hello.JSP):

<%@ page language="java" import="Java.util.*" pageEncoding="GB18030"%>
<%String path = request.getContextPath();%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD Html 4.01 Transitional//EN">
<Html>
  <head>
    <title>AJax提交頁面</title>
 <meta http-equiv="Content-Type" content="text/Html; charset=GB18030">
   <script type="text/Javascript">
    function justdo(){
  var post="name=王力猛&email=wallimn@sohu.com&bokee=http://wallimn.bokee.com";
  post = encodeURI(post);
  post = encodeURI(post);//兩次,很關鍵
  var xmlObj = new ActiveXObject('Msxml2.XMLHTTP');
  var URL = '<%= path%>/page/act.JSP';//文件名需要調整成測試時的相應位置?
  XMLObj.open ('post',URL,true);
  XMLObj.setrequestheader("cache-control","no-cache");
  XMLObj.setrequestheader("Content-Type","application/x-www-form-urlencoded");
  XMLObj.send (post);//注意:POST方式,使用這個來發送內容?
   }
   </script>
  </head> 
  <body>
  <input type="button" value="提交" onclick="justdo()"/>
   </body>
</Html>

/////////////////////////////////////////////////////////////////////////////////////
  AJax請求處理頁面(act.JSP)的內容如下:
/////////////////////////////////////////////////////////////////////////////////////

<%@ page language="java" import="Java.util.*" pageEncoding="GB18030"%>
<%String path = request.getContextPath();%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD Html 4.01 Transitional//EN">
<%@page import="Java.Net.URLDecoder"%>
<Html>
  <head>
    <title>AJax deal</title>
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">   
  </head>
  <body>
  <%
  //遍歷輸出參數內容。
  for (Enumeration e = request.getParameterNames(); e.hasMoreElements();) {
   String h = (String) e.nextElement();
   String v = request.getParameter(h);
   String mm =  Java.Net.URLDecoder.decode(v, "UTF-8");
   System.out.println("請求參數: " + h + " = " + mm);
  }
   %>
  </body>
</Html>

/////////////////////////////////////////////////////////////////////////////////////
分析:當調用request.getParameter()函數時,會自動進行一次URI的解碼過程,調用時內置的解碼過程會導致亂碼出現。而URI編碼兩次後,request.getParameter()函數得到的是原信息URI編碼一次的內容。再用可控的解碼函數Java.Net.URLDecoder.decode()就可解出原始的正確的信息。

以上分析純屬個人看法,不知是否正確。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved