一、前台传递字符串变量,后台返回字符串变量(非json格式)
Javascript代码:
这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对汉字字符串进行了编码,并且对返回
的字符串使用unescape()函数进行解码,使得汉字得以正常显示。当然了,后台PHP代码也添加了头文件,以保证汉字字符串不会出现乱码。各种后台代码解决
汉字乱码问题的方式如下:
PHP:header('Content-Type:text/html;charset=GB2312');
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data="前台变量"<span style="color: #000000;">; </span><span style="color: #008080;"> 3</span> my_data=escape(my_data)+"";<span style="color: #008000;">//</span><span style="color: #008000;">编码,防止汉字乱码</span> <span style="color: #008080;"> 4</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;"> 5</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;"> 6</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;"> 7</span> <span style="color: #000000;"> data:{trans_data:my_data}, </span><span style="color: #008080;"> 8</span> <span style="color: #008000;">//</span><span style="color: #008000;">dataType: "json",</span> <span style="color: #008080;"> 9</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">10</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">11</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">12</span> success: <span style="color: #0000ff;">function</span>(data,status){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">13</span> alert(unescape(data));<span style="color: #008000;">//</span><span style="color: #008000;">解码,显示汉字</span> <span style="color: #008080;">14</span> <span style="color: #000000;"> } </span><span style="color: #008080;">15</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">16</span> <span style="color: #008080;">17</span> });
PHP代码:
<span style="color: #008080;">1</span> <span style="color: #000000;">php </span><span style="color: #008080;">2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码</span> <span style="color: #008080;">3</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;">4</span> <span style="color: #0000ff;">echo</span> <span style="color: #800080;">$backValue</span>."+后台返回"<span style="color: #000000;">; </span><span style="color: #008080;">5</span> ?>
显示效果如下图所示:
二、前台传递多个一维数组,后台返回字符串变量(非json格式)
Javascript代码:
在非json格式下,后台只能返回字符串,如果想后台返回数组,可以采用json格式,在本文的后面会详细介绍。
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 3</span> <span style="color: #0000ff;">var</span> my_data1=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 4</span> my_data[0]=0<span style="color: #000000;">; </span><span style="color: #008080;"> 5</span> my_data[1]=1<span style="color: #000000;">; </span><span style="color: #008080;"> 6</span> my_data[2]=2<span style="color: #000000;">; </span><span style="color: #008080;"> 7</span> <span style="color: #008080;"> 8</span> my_data1[0]=10<span style="color: #000000;">; </span><span style="color: #008080;"> 9</span> my_data1[1]=11<span style="color: #000000;">; </span><span style="color: #008080;">10</span> my_data1[2]=12<span style="color: #000000;">; </span><span style="color: #008080;">11</span> <span style="color: #008080;">12</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;">13</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;">14</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;">15</span> <span style="color: #000000;"> data:{trans_data:my_data,trans_data1:my_data1}, </span><span style="color: #008080;">16</span> <span style="color: #008000;">//</span><span style="color: #008000;">dataType: "json",</span> <span style="color: #008080;">17</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">18</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">19</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">20</span> success: <span style="color: #0000ff;">function</span>(data,status){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">21</span> alert(data); <span style="color: #008080;">22</span> <span style="color: #000000;"> } </span><span style="color: #008080;">23</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">24</span> <span style="color: #008080;">25</span> });
PHP代码:
<span style="color: #008080;"> 1</span> <span style="color: #000000;">php </span><span style="color: #008080;"> 2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码 </span><span style="color: #008080;"> 3</span> <span style="color: #008080;"> 4</span> <span style="color: #008000;"> //读取第一个数组</span> <span style="color: #008080;"> 5</span> <span style="color: #800080;">$backValue</span>="trans_data:"<span style="color: #000000;">; </span><span style="color: #008080;"> 6</span> <span style="color: #800080;">$trans</span>=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;"> 7</span> <span style="color: #0000ff;">foreach</span>(<span style="color: #800080;">$trans</span> <span style="color: #0000ff;">as</span> <span style="color: #800080;">$value</span><span style="color: #000000;">) </span><span style="color: #008080;"> 8</span> <span style="color: #000000;"> { </span><span style="color: #008080;"> 9</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$backValue</span>." ".<span style="color: #800080;">$value</span><span style="color: #000000;">; </span><span style="color: #008080;">10</span> <span style="color: #000000;"> } </span><span style="color: #008080;">11</span> <span style="color: #008080;">12</span> <span style="color: #008000;">//</span><span style="color: #008000;">读取第二个数组</span> <span style="color: #008080;">13</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$backValue</span>." , trans_data1:"<span style="color: #000000;">; </span><span style="color: #008080;">14</span> <span style="color: #800080;">$trans</span>=<span style="color: #800080;">$_POST</span>['trans_data1'<span style="color: #000000;">]; </span><span style="color: #008080;">15</span> <span style="color: #0000ff;">foreach</span>(<span style="color: #800080;">$trans</span> <span style="color: #0000ff;">as</span> <span style="color: #800080;">$value</span><span style="color: #000000;">) </span><span style="color: #008080;">16</span> <span style="color: #000000;"> { </span><span style="color: #008080;">17</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$backValue</span>." ".<span style="color: #800080;">$value</span><span style="color: #000000;">; </span><span style="color: #008080;">18</span> <span style="color: #000000;"> } </span><span style="color: #008080;">19</span> <span style="color: #0000ff;">echo</span> <span style="color: #800080;">$backValue</span><span style="color: #000000;">; </span><span style="color: #008080;">20</span> ?>
显示效果如下图:
三、前台传递多个一维数组,后台返回二维数组(json格式)
Javascript代码:
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 3</span> <span style="color: #0000ff;">var</span> my_data1=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 4</span> my_data[0]=0<span style="color: #000000;">; </span><span style="color: #008080;"> 5</span> my_data[1]=1<span style="color: #000000;">; </span><span style="color: #008080;"> 6</span> my_data[2]=2<span style="color: #000000;">; </span><span style="color: #008080;"> 7</span> <span style="color: #008080;"> 8</span> my_data1[0]=10<span style="color: #000000;">; </span><span style="color: #008080;"> 9</span> my_data1[1]=11<span style="color: #000000;">; </span><span style="color: #008080;">10</span> my_data1[2]=12<span style="color: #000000;">; </span><span style="color: #008080;">11</span> <span style="color: #008080;">12</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;">13</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;">14</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;">15</span> <span style="color: #000000;"> data:{trans_data:my_data,trans_data1:my_data1}, </span><span style="color: #008080;">16</span> dataType: "json"<span style="color: #000000;">, </span><span style="color: #008080;">17</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">18</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">19</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">20</span> success: <span style="color: #0000ff;">function</span>(data){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">21</span> <span style="color: #0000ff;">var</span> back=""<span style="color: #000000;">; </span><span style="color: #008080;">22</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> i=0;i){ <span style="color: #008080;">23</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> j=0;j<data style="color: #000000;">){ <span style="color: #008080;">24</span> back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" "<span style="color: #000000;">; </span><span style="color: #008080;">25</span> <span style="color: #000000;"> } </span><span style="color: #008080;">26</span> back+="\n"<span style="color: #000000;">; </span><span style="color: #008080;">27</span> <span style="color: #000000;"> } </span><span style="color: #008080;">28</span> <span style="color: #000000;"> alert(back); </span><span style="color: #008080;">29</span> <span style="color: #000000;"> } </span><span style="color: #008080;">30</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">31</span> <span style="color: #008080;">32</span> });</data>
PHP代码:
<span style="color: #008080;">1</span> <span style="color: #000000;">php </span><span style="color: #008080;">2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码 </span> <span style="color: #008080;">3</span> <span style="color: #800080;">$backValue</span>=<span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008080;">4</span> <span style="color: #800080;">$backValue</span>[0]=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;">5</span> <span style="color: #800080;">$backValue</span>[1]=<span style="color: #800080;">$_POST</span>['trans_data1'<span style="color: #000000;">]; </span><span style="color: #008080;">6</span> <span style="color: #008080;">7</span> <span style="color: #0000ff;">echo</span> json_encode(<span style="color: #800080;">$backValue</span><span style="color: #000000;">); </span><span style="color: #008080;">8</span> ?>
显示效果如下图:
四、前台传递一维数组和二维数组,后台返回二维数组(json格式)
Javascript代码:
<span style="color: #008080;"> 1</span> $(<span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;"> 2</span> <span style="color: #0000ff;">var</span> my_data=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 3</span> <span style="color: #0000ff;">var</span> my_data1=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 4</span> <span style="color: #0000ff;">var</span> my_data2=<span style="color: #0000ff;">new</span><span style="color: #000000;"> Array(); </span><span style="color: #008080;"> 5</span> <span style="color: #008080;"> 6</span> my_data[0]=0<span style="color: #000000;">; </span><span style="color: #008080;"> 7</span> my_data[1]=1<span style="color: #000000;">; </span><span style="color: #008080;"> 8</span> my_data[2]=2<span style="color: #000000;">; </span><span style="color: #008080;"> 9</span> <span style="color: #008080;">10</span> my_data1[0]=10<span style="color: #000000;">; </span><span style="color: #008080;">11</span> my_data1[1]=11<span style="color: #000000;">; </span><span style="color: #008080;">12</span> my_data1[2]=12<span style="color: #000000;">; </span><span style="color: #008080;">13</span> <span style="color: #008080;">14</span> my_data2[0]=<span style="color: #000000;">my_data; </span><span style="color: #008080;">15</span> my_data2[1]=<span style="color: #000000;">my_data1; </span><span style="color: #008080;">16</span> <span style="color: #008080;">17</span> <span style="color: #000000;"> $.ajax({ </span><span style="color: #008080;">18</span> url: "ajax_php.php"<span style="color: #000000;">, </span><span style="color: #008080;">19</span> type: "POST"<span style="color: #000000;">, </span><span style="color: #008080;">20</span> <span style="color: #000000;"> data:{trans_data:my_data,trans_data1:my_data1,trans_data2:my_data2}, </span><span style="color: #008080;">21</span> dataType: "json"<span style="color: #000000;">, </span><span style="color: #008080;">22</span> error: <span style="color: #0000ff;">function</span><span style="color: #000000;">(){ </span><span style="color: #008080;">23</span> alert('Error loading XML document'<span style="color: #000000;">); </span><span style="color: #008080;">24</span> <span style="color: #000000;"> }, </span><span style="color: #008080;">25</span> success: <span style="color: #0000ff;">function</span>(data){<span style="color: #008000;">//</span><span style="color: #008000;">如果调用php成功 </span> <span style="color: #008080;">26</span> <span style="color: #0000ff;">var</span> back=""<span style="color: #000000;">; </span><span style="color: #008080;">27</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> i=0;i){ <span style="color: #008080;">28</span> <span style="color: #0000ff;">for</span>(<span style="color: #0000ff;">var</span> j=0;j<data style="color: #000000;">){ <span style="color: #008080;">29</span> back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" "<span style="color: #000000;">; </span><span style="color: #008080;">30</span> <span style="color: #000000;"> } </span><span style="color: #008080;">31</span> back+="\n"<span style="color: #000000;">; </span><span style="color: #008080;">32</span> <span style="color: #000000;"> } </span><span style="color: #008080;">33</span> <span style="color: #000000;"> alert(back); </span><span style="color: #008080;">34</span> <span style="color: #000000;"> } </span><span style="color: #008080;">35</span> <span style="color: #000000;"> }); </span><span style="color: #008080;">36</span> <span style="color: #008080;">37</span> });</data>
PHP代码:
<span style="color: #008080;">1</span> <span style="color: #000000;">php </span><span style="color: #008080;">2</span> <span style="color: #008080;">header</span>('Content-Type:text/html; charset=gb2312');<span style="color: #008000;">//</span><span style="color: #008000;">使用gb2312编码,使中文不会变成乱码 </span> <span style="color: #008080;">3</span> <span style="color: #800080;">$backValue</span>=<span style="color: #0000ff;">array</span><span style="color: #000000;">(); </span><span style="color: #008080;">4</span> <span style="color: #800080;">$backValue</span>=<span style="color: #800080;">$_POST</span>['trans_data2'<span style="color: #000000;">]; </span><span style="color: #008080;">5</span> <span style="color: #800080;">$backValue</span>[2]=<span style="color: #800080;">$_POST</span>['trans_data'<span style="color: #000000;">]; </span><span style="color: #008080;">6</span> <span style="color: #800080;">$backValue</span>[3]=<span style="color: #800080;">$_POST</span>['trans_data1'<span style="color: #000000;">]; </span><span style="color: #008080;">7</span> <span style="color: #008080;">8</span> <span style="color: #0000ff;">echo</span> json_encode(<span style="color: #800080;">$backValue</span><span style="color: #000000;">); </span><span style="color: #008080;">9</span> ?>
显示效果如下图:

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。