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

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

网站前端页面设计会用DIV+CSS架构,布局出来的网站外观简洁大气。HTML静态,H5开发+CSS3网站,自适应电脑、手机、平板,符合用户体验的习惯,更容易与用户产生互动。专业网站制作公司的服务理念是“高性价比建站,让企业网站具备营销价值,促进长期合作共赢模式”。

由于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乱码解决示例之客户端

  1. < !DOCTYPE HTML PUBLIC "-//W3C//
    DTD HTML 4.01 Transitional//EN">   

  2. < html>   

  3. < head>   

  4. < meta http-equiv="Content-Type"
     content="text/html; charset=gb2312">   

  5. < title>ajax post test   

  6. < /head>   

  7. < body>   

  8. < div id="msg">< /div>   

  9. < script language="javascript">   

  10. /**   

  11. * 初始化一个xmlhttp对象   

  12. */   

  13. function InitAjax()   

  14. {   

  15. var ajax=false;   

  16. try {   

  17. ajax = new ActiveXObject
    ("Msxml2.XMLHTTP");   

  18. } catch (e) {   

  19. try {   

  20. ajax = new ActiveXObject
    ("Microsoft.XMLHTTP");   

  21. } catch (E) {   

  22. ajax = false;   

  23. }   

  24. }   

  25. if (!ajax && typeof XMLHttp
    Request!='undefined') {   

  26. ajax = new XMLHttpRequest();   

  27. }   

  28. return ajax;   

  29. }   

  30. //在form 测试页面内有一个表单,一个显示的层   

  31. function sendData()   

  32. {   

  33. var msg=document.getElementById("msg");   

  34. var f=document.form1;   

  35. var c=f.content.value;   

  36. //接收数据的URL   

  37. var url="dispmsg.php";   

  38. var poststr="content="+c;   

  39. var ajax=InitAjax();   

  40. ajax.open("POST",url,true);   

  41. ajax.setRequestHeader("Content-Type",
    "application/x-www-form-urlencoded");   

  42. ajax.send(poststr);   

  43. ajax.onreadystatechange=function(){   

  44. if(ajax.readyState==4 && ajax.status==200){   

  45. alert("I got something");   

  46. msg.innerHTML=ajax.responseText;   

  47. }   

  48. }   

  49. }   

  50. < /script>   

  51. < form name='form1'>   

  52. < input type="text" name='content' size=10>   

  53. onclick="sendData()">< !--我用submit时就出错-->   

  54. < /form>   

  55. < /body>   

  56. < /html> 

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

  1. < ?php   

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

  3. if($_POST['content'])   

  4. {   

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

  6. print("内容是".$_POST['content']);   

  7. }   

  8. else   

  9. {   

  10. print("没有内容发送");   

  11. }   

  12. ?>  

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


本文名称:PHP中使用Ajax出现乱码如何解决
URL标题:http://scyanting.com/article/igjhic.html