欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

如何正确处理PHP Ajax乱码_PHP教程

程序员文章站 2022-06-06 12:09:20
...
由于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 testtitle>
  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. input type="button" value="确定"
    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乱码的相关解决方法,希望对又需要的朋友有所帮助。


www.bkjia.comtruehttp://www.bkjia.com/PHPjc/446195.htmlTechArticle由于XMLHTTP采用的是Unicode编码上传数据,而一般页面采用的是gb2312,这就造成显示页面时产生乱码。而当在获取页面时的XMLHttp返回的是utf-8编...