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

发布时间:2021-07-23 16:30:56 作者:Leah
来源:亿速云 阅读:163

这篇文章将为大家详细讲解有关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乱码解决示例之客户端

  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</title>   

  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出现乱码如何解决就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

推荐阅读:
  1. php出现乱码应该如何解决
  2. 怎么解决php页面出现html乱码?

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

php ajax

上一篇:PHP中怎么将字符串转换为数值

下一篇:PHP与Javascript怎么实现交互

相关阅读

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

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