程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 如何正確處理PHP Ajax亂碼

如何正確處理PHP Ajax亂碼

編輯:關於PHP編程

由於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. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved