zoukankan      html  css  js  c++  java
  • AJAX提交数据时 中文处理 以及js url 中文处理

    最近,了解到一些朋友又深陷其中,便把自己以前的解决方法拿出来晒晒,希望对误入该行业的朋友有些帮助。

      原理:html不能设置编码,但是xml可以,我们采用xml,把数据携带过去,不就可以了嘛。

      js核心代码:

    //注:xmlDoc,xmlHtml对象创建请用更完善的方式,这里只是简单演示一下
    function doSubmit(){
     var str=document.getElementById("input1").value;
     //假设str就是你要提交的数据
     alert(str);
     
     //"MSXML2.DOMDocument", "Microsoft.XMLDOM", "MSXML.DOMDocument", "MSXML3.DOMDocument"
     var xmlDoc=new ActiveXObject("MSXML2.DOMDocument");
     
     //初始化xml文档对象
     xmlDoc.loadXML("<html></html>");
     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";
     var xmlHttp=new ActiveXObject("MSXML2.XMLHttp.5.0");
     var url="servlet/MyServlet?time="+(new Date()).getTime();
     xmlHttp.open("POST",url,false);
     xmlHttp.send(xmlDoc);//把xml对象发送出去
     alert(xmlHttp.responseText);
    }

      servlet/action核心代码:

    // 读取ajax发送来的xml数据
     SAXReader xmlReader = new SAXReader();
     Document document = null;
     try {
     document = xmlReader.read(request.getInputStream());
     } catch (Exception ex) {
     System.err.println("xml读取失败,可能没有xml数据.");
     ex.printStackTrace();
     }
     System.out.println("接收到xml数据:" + document.asXML());
      
     // 解析xml
     String str = document.getRootElement().getText();
     System.out.println("解析出来的数据:" + str);
      
     // 返回结果
     response.setContentType("text/html; charset=UTF-8");// GBK也行,指明返回的编码
     response.getWriter().print("服务器返回信息:成功啦!no(∩_∩)o...哈哈!");// 返回中文也没问题啦

    ---------------------------

    在使用url进行参数传递时,经常会传递一些中文名的参数或URL地址,在后台处理时会发生转换错误。在有些传递页面使用GB2312,而在接收页面使用UTF8,这样接收到的参数就可能会与原来发生不一致。使用服务器端的urlEncode函数编码的URL,与使用客户端javascript的 encodeURI函数编码的URL,结果就不一样。

  • 相关阅读:
    windows下的tfjs-node安装异常总结
    微信小游戏广告位iphonex底部适配问题
    JS做深度学习3——数据结构
    JS做深度学习2——导入训练模型
    ASP.NET MVC4网站搭建与发布【最新】
    JS做深度学习1——偶然发现与入门
    聊聊H5与JS近几年的黑科技
    Mysql中让两个字段不同时相同的方法
    JUnit4在Eclipse中的使用
    编写DAO,通过JdbcTemplate操作数据库的实践
  • 原文地址:https://www.cnblogs.com/backuper/p/1361488.html
Copyright © 2011-2022 走看看