您好,登錄后才能下訂單哦!
本篇內容介紹了“AJAX提交數據時的中文亂碼怎么處理”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
原理:html不能設置編碼,但是xml可以,我們采用xml,把數據攜帶過去,不就可以了嘛。
js核心代碼:
//注:xmlDoc,xmlHtml對象創建請用更完善的方式,這里只是簡單演示一下
functiondoSubmit(){
varstr=document.getElementById("input1").value;
//假設str就是你要提交的數據
alert(str);
//"MSXML2.DOMDocument","Microsoft.XMLDOM","MSXML.DOMDocument","MSXML3.DOMDocument"
varxmlDoc=newActiveXObject("MSXML2.DOMDocument");
//初始化xml文檔對象
xmlDoc.loadXML("");
xmlDoc.documentElement.text=str;//作為內容去攜帶
//如果采用屬性攜帶數據更方便,那么可以用下面的方法
//xmlDoc.documentElement.setAttribute("name","msg");
//xmlDoc.documentElement.setAttribute("value",str);
alert(xmlDoc.xml);//查看生成的xml內容
//"MSXML2.XMLHttp.5.0","MSXML2.XMLHttp.4.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp","Microsoft.XMLHttp";
varxmlHttp=newActiveXObject("MSXML2.XMLHttp.5.0");
varurl="servlet/MyServlet?time="+(newDate()).getTime();
xmlHttp.open("POST",url,false);
xmlHttp.send(xmlDoc);//把xml對象發送出去
alert(xmlHttp.responseText);
}
AJAX提交數據時的中文怎么處理
servlet/action核心代碼:
//讀取ajax發送來的xml數據
SAXReaderxmlReader=newSAXReader();
Documentdocument=null;
try{
document=xmlReader.read(request.getInputStream());
}catch(Exceptionex){
System.err.println("xml讀取失敗,可能沒有xml數據.");
ex.printStackTrace();
}
System.out.println("接收到xml數據:"+document.asXML());
//解析xml
Stringstr=document.getRootElement().getText();
System.out.println("解析出來的數據:"+str);
//返回結果
response.setContentType("text/html;charset=UTF-8");//GBK也行,指明返回的編碼
response.getWriter().print("服務器返回信息:成功啦!\no(∩_∩)o...哈哈!");//返回中文也沒問題啦
關鍵點:
js中創建xmlDom對象,以及后臺的解析,后臺用了dom4j,來解析xml。
“AJAX提交數據時的中文亂碼怎么處理”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。