主页 > 知识库 > AJAX乱码解决新方法

AJAX乱码解决新方法

热门标签:电销机器人违法了吗 上海浦东腾讯地图标注位置 姜堰电销机器人 海南银行智能外呼系统商家 辽宁银行智能外呼系统 许昌智能电销机器人公司 辽宁正规电销机器人 澳大利亚城市地图标注 辰溪地图标注
用过AJAX的朋友肯定知道javascript是使用UTF-8国际编码,即每个汉字用3个字节来存储,但是这就造成了用AJAX来send数据的时候出现乱码。 
   有一种解决办法就是使用encodeURIComponent加上修改 Content-Type 为 application/x-www-form-urlencoded" 来把数据统一编码成 url 格式,但是这样做有一个弊端,使用php的urldecode根本不能得到正确的文字。 
   另一种方法就是通过vbscript 的写的函数把数据转成gb2312格式的,我个人觉得这种方法比较好。有兴趣的朋友可以到网上去查一下。 
   今天突发奇想,AJAX调用的时候会不会发送cookie 呢?马上写了一个程序测试一下,果然能,这样就可以在调用ajax之前,先把数据通过javascript写到cookie里,然后再send就可以将cookie里的数据发送出去了,太爽了!! 

演示地址:http://cn5.cn/ajax/ajax12.htm 

客户端代码 ajax.htm 
复制代码 代码如下:

title>AJAX使用cookie传值例子/title>  
script>  
var oDiv         
var xh                
function getXML()  
{  
    setcookie($('name').value,$('val').value);  
    oDiv = document.all.m  
    oDiv.innerHTML = "正在装载,请稍侯......."  
    oDiv.style.display= ""  
    xh = new ActiveXObject("Microsoft.XMLHTTP")  
    xh.onreadystatechange = getReady  
    xh.open("POST","a.php",false)  
    xh.send();  
}  

function getReady()  
{  
    if(xh.readyState==4)  
    {  
        if(xh.status==200)  
        {  
            oDiv.innerHTML = "完成"  
        }  
        else  
        {  
             oDiv.innerHTML = "抱歉,装载数据失败。原因:" + xh.statusText  
        }  
  }  
} //author : longbill      www.longbill.cn  

function setcookie(name,value)  
{  
    var cookiestr=name+"="+value+";";  
    var expires = "";  
    var cookieexp=60*60*1000;  
    var d = new Date();  
    d.setTime( d.getTime() + cookieexp);  
    expires = "expires=" + d.toGMTString()+";";  
    document.cookie = cookiestr+ expires;  
}  
function $(a)  
{  
    return document.getElementById(a);  
}  
/script>  

body>  
AJAX使用cookie传值例子:br>  
form name=myform>  
name:input id=name  value="变量名甚至可以是中文" size=20>br>  
value:input type=text size=20 id=val value=这里>br>  
input onclick="getXML()" type="button" value="送出数据">  
input onclick="if(xh  xh.responseText) {alert(xh.responseText);}" type="button" value="显示返回结果">br>  
div id=m bgcolor=blue>在此显示状态/div>  
input type=button onclick="alert(document.cookie)" value=显示本地COOKIE>  
/form> 

服务器端代码 a.php 
复制代码 代码如下:

?  
header("Content-type: text/html;charset=GB2312");  
echo "以下是您送出的所有COOKIE变量及其值\n";  
print_r($_COOKIE);  
?>
您可能感兴趣的文章:
  • php Ajax乱码
  • Ajax乱码问题整理
  • ajax中文乱码的各种解决办法总结
  • AJAX中文乱码PHP中完美解决方法
  • ajax+php中文乱码解决办法
  • AJAX在Post中文的时候乱码的解决方法
  • ajax中文乱码问题解决方案

标签:威海 铜川 晋城 崇左 抚州 深圳 西藏 伊春

巨人网络通讯声明:本文标题《AJAX乱码解决新方法》,本文关键词  AJAX,乱码,解决,新方法,AJAX,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《AJAX乱码解决新方法》相关的同类信息!
  • 本页收集关于AJAX乱码解决新方法的相关信息资讯供网民参考!
  • 推荐文章