如何正确处理PHP Ajax乱码

开发 后端
PHP Ajax乱码的出现一般都是因为页面采用了gb2312,从而造成显示页面时产生乱码。我们在文章中给出了两种解决方法,供大家参考学习。

PHP语言功能虽然强大,但是在实际编程中难免会遇到一些问题,只有偶很好的解决了这些问题,才能更熟练的掌握运用这门语言。下面我们就向大家介绍PHP Ajax乱码的具体解决方法。

#t#由于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乱码的相关解决方法,希望对又需要的朋友有所帮助。

责任编辑:曹凯 来源: 百度博客
相关推荐

2010-05-21 11:07:55

MySQL 5 乱码问

2019-01-07 15:42:00

JavaScript前端 编码

2021-12-31 18:20:44

数据云端数据迁移

2009-12-07 15:50:27

WCF文件

2010-02-24 10:35:56

WCF链接服务超时

2010-09-30 10:31:28

2024-01-29 00:21:14

环境变量数据

2020-09-14 18:47:03

云安全

2017-10-10 15:30:20

JavaScript

2021-09-23 22:36:30

手机数据二手

2024-01-29 00:45:36

跨域后端接口

2010-05-07 13:28:43

Oracle数据库

2017-10-30 11:03:11

2009-12-03 13:10:06

2009-02-27 16:57:51

AJAX判断请求

2009-12-02 16:38:26

PHP发送邮件函数

2009-12-03 11:11:57

PHP网站优化

2021-11-19 10:16:12

首席信息官技术发展企业管理者

2010-01-07 16:50:54

Linux配置PHP环

2009-12-03 20:09:03

Tomcat支持PHP
点赞
收藏

51CTO技术栈公众号