在服务器端的XSLT过程中出现的编码问题解决方案

最近和苹果皮在讨论优化 weather for google earth 的时候使用到了 xslt 来转换 xml 数据的问题,那这里就必须用到转换引擎,大概过程就是把 xml 文件和 xslt 文件都转载到内存里用dom引擎进行转换到我们想要的 html(我这个实例里是要生成 kml 文件)。这个转换的过程又分客户端和服务器端的,因为客户端的转换需要用户的浏览器完整地支持 xml ,但不是全部的用户的浏览器现在都支持的(ie5、ie4等),所以进行服务端的转换是比较理想的。
    xml文件形式:

    [...]      [...]          [...]                 10/28/06 11:16 AM Local Time       [...]              [...]              

登录后复制

    XSLT文件形式(内容部分省略):

           [...] 

登录后复制

    我开始进行的转换代码,用的是ASP+JavaScirpt :

//========输出类型和流编码==========================
      

Response.ContentType = "application/vnd.google-earth.kml+xml";       Response.CharSet = "UTF-8" ;

登录后复制

//=====获得并载入远程XML文件==========================

 var oXHy = Server.CreateObject("MSXML2.XMLHTTP");       var url  = http://www.dnxh.cn/ge/CHXX0101.xml;         oXHy.open("GET",url,false);       oXHy.send();       var oXD = Server.CreateObject("MSXML2.DOMDocument");       oXD.loadXML(oXHy.responseText);

登录后复制

//======载入XSL文件=========================

var xsl = Server.CreateObject("Microsoft.XMLDOM");       xsl.async = false;       xsl.load(Server.MapPath("gew.xsl"));

登录后复制

//======文件的转换====================
      Response.Write(oXD.transformNode(xsl)); 
    按理说这样应该没有编码的问题了,因为该声明编码的地方都声明了。可是偏偏出了问题。输出的 KML 文件的开头声明里面总是

  

登录后复制

   通过测试发现 XML 和 XSLT 两个源文件没有问题,那问题就在 ASP 代码里的转换引擎上,后来在RE: [xsl] Problem with Chinese (Solution)这篇文章上大概的找到了原因,这里面说引擎 transformNode 是生成了一个字符串,而在 win32 平台上总是以 UTF-16 来处理字符串的,然后我们再用这个字符串来生成 KML 文件,那结果就只能是 UTF-16 的了。
    解决的办法就是用 transformNodeToObject 引擎。文件转换部分换成 oXD.transformNodeToObject( xsl , Response)。这两个方法的不同之处就是前一个是生成了一个字符串变量,后一个是直接把转换后的 XML 数据保存到指定的节点里了。

以上就是在服务器端的XSLT过程中出现的编码问题解决方案的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2417894.html

(0)
上一篇 2025年3月3日 02:04:18
下一篇 2025年2月26日 23:23:17

AD推荐 黄金广告位招租... 更多推荐

发表回复

登录后才能评论