JavaScript中解决Microsoft.XMLHTTP乱码的最简单方法

简介:
+关注继续查看

以下函数为自定义组件 bluec.bluecData2 的代码:
function execSql(pSql, params)
{
    var result = -3;
    formDoc = "<sqls>\n" +
              "<sql>" + pSql + "</sql>\n" +
              "</sqls>";
    var oXmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
    oXmlHttp.Open("POST", "../util/execsql.asp", false);
    oXmlHttp.setRequestHeader("Content-Type", "text/xml");
    oXmlHttp.setRequestHeader("charset", "utf-8");

    oXmlHttp.Send(formDoc);
    if (oXmlHttp.status == 200)
    {
        var rText = oXmlHttp.responseText;
        if (rText.substring(0,1) == "0")
        {
            return true;
        }
        else
        {
            return false;
        }
    }

    return false;
}

调用 bluec.bluecData2 组件的页面内容:
<%@LANGUAGE="JAVASCRIPT" CODEPAGE="936"%>
<%
var errMsg = "0";
obj = new ActiveXObject("bluec.bluecData2");
errMsg = obj.execSql(Request);
Response.Charset = "utf-8";
Response.ContentType = "text/xml";
Response.Write(errMsg);
obj = null;
%>

当errMsg包含中文时,oXmlHttp.responseText 返回的值是乱码,怪了,在 jsp 中同样的实现方法居然没有问题。
在网上搜索,发现解决最重要的解决办法是写一个函数来转换 oXmlHttp.responseText 的编码格式。
该 VBScript 函数是 byte2sBSTR,但是我的代码全部是 JavaScript,据说 JavaScript 也可以直接调用 VBScript 函数,心里好不舒服,这些小问题好花时间。
继续搜索吧,看有没有纯 JavaScript 的解决办法,在一个论坛上发现一个高手对此问题的回复:
    unescape
真是简单之至,点到为止。unescape 有什么用,通过实验:
    var rText = oXmlHttp.responseText; 改成 var rText = unescape(oXmlHttp.responseText);
    且
    Response.Write(errMsg); 改成 Response.Write(escape(errMsg));
居然OK了,太棒了。
 

 

分类: Javascript

本文转自快乐就好博客园博客,原文链接:http://www.cnblogs.com/happyday56/archive/2008/01/23/1050075.html,如需转载请自行联系原作者
相关文章
|
10月前
|
JavaScript 前端开发
JavaScript判断各种资源是否加载完成的方法汇总,资源预加载问题
JavaScript判断各种资源是否加载完成的方法汇总,资源预加载问题
384 0
|
10月前
|
JavaScript 前端开发
JavaScript中Date对象的方法解析
JavaScript中Date对象的方法解析 上篇文章讲到了JavaScript的Date对象,对Date对象的创建和属性进行了讲解,这篇博客我们来讲一讲Date对象的方法有哪些。 1.获取日期的方法 // 获取当前的日期 var oDate=new Date(); // 方法 描述 // getDate() 从 Date 对象返回一个月中的某一天 (1 ~ 31)。 console.log(oDate.getDate()); // getDay() 从 Date 对象返回一周中的某一天 (0 ~ 6)。 c
|
10月前
|
JavaScript 前端开发
JavaScript的字符串之HTML包装方法
JavaScript的字符串之HTML包装方法 前面以前文章我们讲解了字符串的各种方法。这篇文章对字符串的方法进行一些补充。 1.字符串的indexOf()和lastIndexOf()方法的补充 var str=&#39;hello world&#39;; // indexOf() lastIndexOf() // 不加第二个参数 console.log(str.indexOf(&quot;l&quot;);// 2 console.log(str.lastIndexOf(&quot;l&quot;);// 9 console.log(str.indexOf(&quot;l&quot;,5));// 9 5之后
|
10月前
|
JavaScript 前端开发 索引
JavaScript数组对象的迭代方法详解
JavaScript数组对象的迭代方法详解 上一篇博客讲到了数组的方法,当然里边比较复杂的就是数组的迭代方法,因为涉及到了回调函数,所以这篇博客我们来详细讲解一下js数组迭代方法的使用。 1.forEach(funcrion(value,index,arr){}):对数组的每一项运行给定函数,这个方法不进行返回,所以一般用于让数组循环执行某方法。 var arr=[1,2,3,4,5,6]; arr.forEach(function(val,index,arr){ console.log(val,index,arr); }) // 其中:
|
10月前
|
设计模式 JavaScript 前端开发
【JavaScript】面向对象——创建多个对象的四种方法(详解)
【JavaScript】面向对象——创建多个对象的四种方法(详解)
112 0
|
10月前
|
JavaScript 前端开发
JavaScript函数柯里化的实现原理,进来教你完成一个自己的自动实现柯里化方法
JavaScript函数柯里化的实现原理,进来教你完成一个自己的自动实现柯里化方法
143 0
|
10月前
|
JavaScript 前端开发
JavaScript总结:typeof与instanceof的区别,及Object.prototype.toString()方法
JavaScript总结:typeof与instanceof的区别,及Object.prototype.toString()方法
116 0
JavaScript总结:typeof与instanceof的区别,及Object.prototype.toString()方法
|
10月前
|
JavaScript 前端开发 Go
加载Javascript脚本的方法
加载Javascript脚本的方法
105 0
|
11月前
|
JavaScript
JS 实现给数字加三位一逗号间隔的两种方法
JS 实现给数字加三位一逗号间隔的两种方法
|
11月前
|
JavaScript 安全 索引
JS数组reduce()方法详解及高级技巧
JS数组reduce()方法详解及高级技巧
相关产品
云迁移中心
推荐文章
更多