温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PHP中使用Ajax出现乱码如何解决

发布时间:2021-07-23 16:30:56 阅读:167 作者:Leah 栏目:编程语言
PHP开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

这篇文章将为大家详细讲解有关PHP中使用Ajax出现乱码如何解决,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

由于XMLHTTP采用的是Unicode编码上传数据,而一般页面采用的是gb2312,这就造成显示页面时产生乱码。而当在获取页面时的XMLHttp返回的是utf-8编码,这就造成了显示产生乱码。

PHP Ajax乱码解决方法之一就是在PHP文件中显示声明为GB2312

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

而对于发送到服务器的中文进行转码。

如下

$_POST["content"]=iconv("UTF-8","gb2312",$_POST["content"]);

因而这样可以解决PHP Ajax乱码问题

方法二,是都采用UTF-8编码。这里就不多说了

PHP Ajax乱码解决示例之客户端

< !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">   < html>   < head>   < meta http-equiv="Content-Type" content="text/html; charset=gb2312">   < title>ajax post test</title>   < /head>   < body>   < div id="msg">< /div>   < script language="javascript">   /**   * 初始化一个xmlhttp对象   */   function InitAjax()   {    var ajax=false;    try {   ajax = new ActiveXObject("Msxml2.XMLHTTP");    } catch (e) {   try {    ajax = new ActiveXObject("Microsoft.XMLHTTP");   } catch (E) {    ajax = false;   }    }    if (!ajax && typeof XMLHttpRequest!='undefined') {   ajax = new XMLHttpRequest();    }    return ajax;   }   //在form 测试页面内有一个表单,一个显示的层   function sendData()   {   var msg=document.getElementById("msg");   var f=document.form1;   var c=f.content.value;   //接收数据的URL   var url="dispmsg.php";   var poststr="content="+c;   var ajax=InitAjax();   ajax.open("POST",url,true);   ajax.setRequestHeader("Content-Type","application/x-www-form-urlencoded");   ajax.send(poststr);   ajax.onreadystatechange=function(){   if(ajax.readyState==4 && ajax.status==200){   alert("I got something");   msg.innerHTML=ajax.responseText;   }   }   }   < /script>   < form name='form1'>   < input type="text" name='content' size=10>   <input type="button" value="确定" onclick="sendData()">< !--我用submit时就出错-->   < /form>   < /body>   < /html> 

PHP Ajax乱码解决示例之服务器端

< ?php   header("Content-Type:text/html;charset=GB2312");   if($_POST['content'])   {   $_POST["content"]=iconv("UTF-8","gb2312",$_POST["content"]);   print("内容是".$_POST['content']);   }   else   {   print("没有内容发送");   }   ?>  

关于PHP中使用Ajax出现乱码如何解决就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI

开发者交流群×