php+AJAX传送中文会导致乱码的问题的解决方法

//如果传送参数是直接赋予的,就会产生乱码! <div class="codetitle"><a style="CURSOR: pointer" data="8323" class="copybut" id="copybut8323" onclick="doCopy('code8323')"> 代码如下:

<div class="codebody" id="code8323">
HTTP_Request.open("POST",url,true);
HTTP_Request.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
HTTP_Request.send("action="+strName+"&val="+val); //如果val的值为中文,则产生乱码
//解决方法很简单:使用javascript中的escape(string) 函数
<div class="codetitle"><a style="CURSOR: pointer" data="37" class="copybut" id="copybut37" onclick="doCopy('code37')"> 代码如下:
<div class="codebody" id="code37">
HTTP_Request.open("POST",'application/x-www-form-urlencoded');
HTTP_Request.send("action="+strName+"&val="+escape(val)); //val的值为中文不会产生乱码

关于在AJAX中GET回的ResponseText中文乱码的最简解决办法
用AJAX来GET回一个页面时,RESPONSETEXT里面的中文多半会出现乱码,这是因为xmlhttp在处理返回的responseText的时候,是把resposeBody按UTF-8编码进解码考形成的,如果服务器送出的确实是UTF-8的数据流的时候汉字会正确显示,而送出了GBK编码流的时候就乱了。解决的办法就是在送出的流里面加一个HEADER,指明送出的是什么编码流,这样XMLHTTP就不会乱搞了。 <div class="codetitle"><a style="CURSOR: pointer" data="78011" class="copybut" id="copybut78011" onclick="doCopy('code78011')"> 代码如下:
<div class="codebody" id="code78011">
PHP:header('Content-Type:text/html;charset=GB2312');
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");

AJAX中文中文中文乱码乱码

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...