现在的位置: 首页 > web前端 > 正文

AJAX提交数据时的中文怎么处理

2020年05月20日 web前端 ⁄ 共 1681字 ⁄ 字号 评论关闭

  AJAX不是新的编程语言,而是一种使用现有标准的新方法。AJAX是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下。下面学步园小编来讲解下AJAX提交数据时的中文怎么处理?

  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提交数据时的中文怎么处理”的内容,希望对大家有用。更多资讯请关注学步园。学步园,您学习IT技术的优质平台!

抱歉!评论已关闭.