AJAX中文乱码解决新方法分享_AJAX相关教程-查字典教程网
AJAX中文乱码解决新方法分享
AJAX中文乱码解决新方法分享
发布时间:2016-12-29 来源:查字典编辑
摘要:用过AJAX的朋友肯定知道javascript是使用UTF-8国际编码,即每个汉字用3个字节来存储,但是这就造成了用AJAX来send数据的...

用过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里的数据发送出去了,太爽了!!

客户端代码 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 type="button" value="送出数据">

<input type="button" value="显示返回结果"><br>

<div id=m bgcolor=blue>在此显示状态</div>

<input type=button value=显示本地COOKIE>

</form>

服务器端代码 a.php

复制代码 代码如下:

<?

header("Content-type: text/html;charset=GB2312");

echo "以下是您送出的所有COOKIE变量及其值n";

print_r($_COOKIE);

?>

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新AJAX相关学习
    热门AJAX相关学习
    编程开发子分类