关于XMLHTTP客户端与ASP交互传输XML时所产生的中文编码问题的解决方案

原创 2006年05月18日 21:24:00

测试通过系统:WinXP 中文Pro, XML4.0 SP2,C#

  尝试过XMLHTTP作客户端,然后尝试与服务器端ASP交互的程序员,我认为都很有思路,当然这也是在自夸:)。但最头疼的问题恐怕就是中文乱码的问题,查了很多资料,MSDN,互联网上的,尝试了很多方法都不太奏效,还好没有气馁,现在,最新的最简单的解决办法闪亮登场:

把客户端要传输的XML的头由:

<?xml version="1.0" encoding="gb2312" ?>

改为:

<?xml version="1.0" encoding="utf-8" ?>

服务器端的ASP程序发送给客户端XML结果时需要加:

Response.ContentType = "text/xml"
Response.CharSet = "gb2312"

客户端的程序取返回结果用XmlDom.loadXml(xmlhttp.responseText)就可以了。

 ============================================================================

以下分析可能的原因:

可能是我们的操作系统本身使用UTF-8编码的原因。

把所有Request.ServerVariables写到一个文本文件中你会发现类似这些:

ALL_HTTP:HTTP_ACCEPT:*/*
HTTP_ACCEPT_LANGUAGE:zh-cn
HTTP_CONNECTION:Keep-Alive
HTTP_HOST:localhost
HTTP_USER_AGENT:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727; InfoPath.1)
HTTP_COOKIE:ASPSESSIONIDAQBCSQRA=FNEHNOCCMHECCOPIOKKECEFM
HTTP_CONTENT_LENGTH:94
HTTP_CONTENT_TYPE:text/xml;charset=gb2312
HTTP_ACCEPT_ENCODING:gzip, deflate
HTTP_CACHE_CONTROL:no-cache

ALL_RAW:Accept: */*
Accept-Language: zh-cn
Connection: Keep-Alive
Host: localhost
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727; InfoPath.1)
Cookie: ASPSESSIONIDAQBCSQRA=FNEHNOCCMHECCOPIOKKECEFM
Content-Length: 94
Content-Type: text/xml;charset=gb2312
Accept-Encoding: gzip, deflate
Cache-Control: no-cache

APPL_MD_PATH:/LM/W3SVC/1/Root/zdqs
APPL_PHYSICAL_PATH:C:/Inetpub/systems/ZDS/qry/
AUTH_PASSWORD:
AUTH_TYPE:
AUTH_USER:
CERT_COOKIE:
CERT_FLAGS:
CERT_ISSUER:
CERT_KEYSIZE:
CERT_SECRETKEYSIZE:
CERT_SERIALNUMBER:
CERT_SERVER_ISSUER:
CERT_SERVER_SUBJECT:
CERT_SUBJECT:
CONTENT_LENGTH:94
CONTENT_TYPE:text/xml;charset=gb2312
GATEWAY_INTERFACE:CGI/1.1
HTTPS:off
HTTPS_KEYSIZE:
HTTPS_SECRETKEYSIZE:
HTTPS_SERVER_ISSUER:
HTTPS_SERVER_SUBJECT:
INSTANCE_ID:1
INSTANCE_META_PATH:/LM/W3SVC/1
LOCAL_ADDR:127.0.0.1
LOGON_USER:
PATH_INFO:/zdqs/QURY.asp
PATH_TRANSLATED:C:/Inetpub/systems/ZDS/qry/QURY.asp
QUERY_STRING:
REMOTE_ADDR:127.0.0.1
REMOTE_HOST:127.0.0.1
REMOTE_USER:
REQUEST_METHOD:POST
SCRIPT_NAME:/zdqs/QURY.asp
SERVER_NAME:localhost
SERVER_PORT:80
SERVER_PORT_SECURE:0
SERVER_PROTOCOL:HTTP/1.1
SERVER_SOFTWARE:Microsoft-IIS/5.1
URL:/zdqs/QURY.asp
HTTP_ACCEPT:*/*
HTTP_ACCEPT_LANGUAGE:zh-cn
HTTP_CONNECTION:Keep-Alive
HTTP_HOST:localhost
HTTP_USER_AGENT:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50727; InfoPath.1)
HTTP_COOKIE:ASPSESSIONIDAQBCSQRA=FNEHNOCCMHECCOPIOKKECEFM
HTTP_CONTENT_LENGTH:94
HTTP_CONTENT_TYPE:text/xml;charset=gb2312
HTTP_ACCEPT_ENCODING:gzip, deflate
HTTP_CACHE_CONTROL:no-cache

猜测一:网络传输过程中所用的编码方式是gb2312

然后,请看另外MSXML4 SDK中一个帮助:

 

Enforcing Character Encoding with DOM

In some cases, an XML document is passed to and processed by an application—for example, an ASP page—that cannot properly decode rare or new characters. When this happens, you might be able to work around the problem by relying on DOM to handle the character encoding. This bypasses the incapable application.

For example, the following XML document contains the character entity ("&#8364;") that corresponds to the Euro currency symbol (). The ASP page, incapable.asp, cannot process currency.xml.

XML Data (currency.xml)

<?xml version="1.0" encoding="utf-8"?>
<currency>
   <name>Euro</name>
   <symbol>&#8364;</symbol>
   <exchange>
      <base>US___FCKpd___0lt;/base>
      <rate>1.106</rate>
   </exchange>
</currency>

ASP Page (incapable.asp)

<%@language = "javascript"%>
<%
   var doc = new ActiveXObject("Msxml2.DOMDocument.4.0");
   doc.async = false;
   if (doc.load(Server.MapPath("currency.xml"))==true) {
      Response.ContentType = "text/xml";
      Response.Write(doc.xml);
   }
%>

When incapable.asp is opened from a Web browser, an error such as the following results:

An invalid character was found in text content. Error processing resource 'http://MyWebServer/MyVirtualDirectory/incapable.asp'. Line 4, Position 10

This error is caused by the use of the Response.Write(doc.xml) instruction in the incapable.asp code. Because it calls upon ASP to encode/decode the Euro currency symbol character found in currency.xml, it fails.

However, you can fix this error. To do so, replace this Response.Write(doc.xml) instruction in incapable.asp with the following line:

doc.save(Response);

With this line, the error does not occur. The ASP code does produce the correct output in a Web browser, as follows:

  <?xml version="1.0" encoding="utf-8" ?> 
  <currency>
    <name>Euro</name> 
    <symbol></symbol> 
    <exchange>
      <base>US$</base> 
      <rate>1.106</rate> 
    </exchange>
  </currency>

The effect of the change in the ASP page is to let the DOM object (doc)—instead of the Response object on the ASP page—handle the character encoding.

请看最后一句:上例中ASP的改变在于让DOM对象(doc)——而不是ASP中的Response对象——处理字符编码。

所以得出:

猜想二:你可以视Request或Response对象为一个文件句柄,如果是用DOM对象的load与save方法时。

由猜想一、猜想二得出

猜想三:客户端编译的系统使用的字符串本身就是采用GB2312编码的,而使用XMLHTTP传输数据时自动转换为GB2312,服务器端用DOM对象load时由于相当于载入一个字节流,然后一看xml头中的encoding就是GB2312,所以就没做转换,直接把字节流视为字符串!!!不好意思是它的确忘记了一件事就是,这个字符串在我的系统显示时却认为是UTF-8编码的,所以只有强制xml转换以下就行了,好像见别人的解决方案时也有写gb2312到utf-8转换函数的……

最后实践,证实可行!!!

用一句话概括就是,客户端发送给服务器的XML,encoding全部为utf-8编码的;服务器发送给客户端,全部指定编码为:gb2312,一切OK。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

xmlhttp中文乱码之客户端解决方案

xmlhttp中文乱码之客户端解决方案 2006-10-23 01:45使用ajax的人,最头疼的莫过于处理返回的中文乱码问题。如果可以在服务器进行操作的话,这个问题并不复杂。问题是有时候我们没有在服...
  • smeyou
  • smeyou
  • 2011-06-10 12:07
  • 2429

关于从java客户端到数据库的数据转换中的编码问题的解决方案

xia 1.java客户端 (1)

ASP.NET Ajax 客户端框架未能加载解决方案

今天在做项目时,需要重新部署一台测试环境,折腾差不多了之后访问网站,就开始提示了"错误: ASP.NET Ajax 客户端框架未能加载"的错误,而且是连续爆出一下错误,这是在其它部署环境上没遇到过的问...

android客户端提交数据到服务器中文乱码三种解决方案

在开始学android的时候提交数据到服务器出现中文乱码问题,经过多方面查资料终于将漂亮的中文在服务器端获取到了.下面总结出三种方法可已经中文乱码解决. 第一种.在客户端适用HttpPost方式提交...

PHP获取客户端数据保存到MySQL数据库 出现中文乱码解决方案

<?php /** * 添加电子优惠券 联系人信息 * 1.连接数据库 $conn=mysql_connect("localhost","user","password") or die...

appcan客户端/js网络传输中文乱码问题解决

3.1 网络传输原理 在HTTP协议中,浏览器不能向服务器直接传递某些特殊字符,必须是这些字符进行URL编码后再进行传送。url编码遵循的规则: 1)将空格转换为(+); 2)对0-9,a-z,A-...

jquery+jsp+servlet做$.ajax交互时出现中文乱码(字符集问题)的解决方案

今天在用jquery的$.ajax方法做异步交互时遇到很蛋疼的中文乱码问题,折腾了好几个小时,终于解决了。现在我就详细地说明一下问题的解决经过。 我的最终代码如下: 代码段一:(getResu...

Asmact实现IM客户端所遇到的问题及解决方案

报错: NoFoundClassError 原因:  smact.jar是windows上的IM实现JAR包,因为android对JAVA类进行了修改,故不能直接使用此JAR包 解决方案:  an...

关于axis2的RPCServiceClient客户端无法传参问题的解决方案

本内容链接上一篇博客。关于如何访问webservice的问题 axis2方式的rpcserviceclient客户端方式调用webservice一般方式如下: RPCServiceClient...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)