Ajax中的JSON格式與php傳輸過(guò)程全面解析
在Ajax中的JSON格式與php傳輸過(guò)程中有哪些要注意的小地方呢?
先來(lái)看一下簡(jiǎn)單通用的JSON與php傳輸數(shù)據(jù)的代碼
HTML文件:
<input type="button" value="Ajax" id="btn"> <script> var btn = document.getElementById("btn"); btn.onclick = function(){ var xhr = getXhr(); xhr.open("post","測(cè)試.php"); xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); var user = '{"name":"zhangwuji","pwd":"123456"}'; xhr.send("user="+user); xhr.onreadystatechange = function(){ if(xhr.readyState==4&&xhr.status==200){ var data = xhr.responseText; var json = eval("("+data+")"); console.log(json); } } } function getXhr(){ var xhr = null; if(window.XMLHttpRequest){ xhr = new XMLHttpRequest(); }else{ xhr = new ActiveXObject("Microsoft.XMLHttp"); } return xhr; } </script>
在整個(gè)過(guò)程中先要獲得AJAX對(duì)象,然后用POST請(qǐng)求方式與PHP文件連接,這時(shí)候用的是POST方法請(qǐng)求數(shù)據(jù),所以這時(shí)候還要加上一個(gè)請(qǐng)求文件頭
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
這是固定寫(xiě)法直接記下來(lái)就可以了。<br><br>上面的是測(cè)試代碼,創(chuàng)建一個(gè)json格式的字符串并用SEND方法傳入PHP:
var user = '{"name":"zhangwuji","pwd":"123456"}';
xhr.send("user="+user);<br><br>
這時(shí)候要注意了,在構(gòu)建JSON字符串傳輸?shù)臅r(shí)候user里面的字符串外面要用單引,里面用雙引,不然php那邊是不認(rèn)為你這是JSON 不能正確的進(jìn)行解析。<br><br><br>這時(shí)候看看PHP文件里的代碼:
<?php // 接收客戶(hù)端發(fā)送的請(qǐng)求數(shù)據(jù) $user = $_POST['user']; // 就是一個(gè)JSON格式的string字符串 $json_user = json_decode($user,true);//對(duì)json格式的字符串進(jìn)行解碼,轉(zhuǎn)換成PHP變量格式 // 2. 使用json_encode()函數(shù) echo json_encode($json_user);//對(duì)php變量格式進(jìn)行編碼,轉(zhuǎn)換成JSON格式 ?>
json_decode 和json_encode大家從字面的意思都應(yīng)該可以看出來(lái)一點(diǎn),decode在這這里的作用就是
對(duì)json格式的字符串進(jìn)行解碼,轉(zhuǎn)換成PHP變量格式
而encode就是
對(duì)php變量格式進(jìn)行編碼,轉(zhuǎn)換成JSON格式在傳輸回去;
這時(shí)候PHP 文件的工作已經(jīng)結(jié)束了,讓我們?cè)诨氐紿TML文件看接受數(shù)據(jù)的onreadystatechange這一塊的代碼
:
var data = xhr.responseText;
雖然PHP文件傳輸回來(lái)的是一個(gè)JSON格式,但是我們這里接受用的是respenseText所以接收到的只是一個(gè)文本格式的字符串<br>這時(shí)候我們還要用eval();函數(shù)將其轉(zhuǎn)換成JSON格式
* 使用eval()函數(shù)進(jìn)行轉(zhuǎn)換 使用"()"將其包裹,eval()函數(shù)強(qiáng)制將其轉(zhuǎn)換為JSON格式(javascript代碼) 不使用"()"將其包裹,eval()函數(shù)將其識(shí)別為一個(gè)空的代碼塊
總結(jié)
以上所述是小編給大家介紹的Ajax中的JSON格式與php傳輸過(guò)程全面解析,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- php+xml結(jié)合Ajax實(shí)現(xiàn)點(diǎn)贊功能完整實(shí)例
- php中XMLHttpRequest(Ajax)不能設(shè)置自定義的Referer的解決方法
- ajax調(diào)用返回php接口返回json數(shù)據(jù)的方法(必看篇)
- php基于jquery的ajax技術(shù)傳遞json數(shù)據(jù)簡(jiǎn)單實(shí)例
- ajax處理php返回json數(shù)據(jù)的實(shí)例代碼
- PHP 與 js的通信(via ajax,json)
- php+ajax+json 詳解及實(shí)例代碼
- jQuery通過(guò)ajax請(qǐng)求php遍歷json數(shù)組到table中的代碼(推薦)
- PHP Ajax JavaScript Json獲取天氣信息實(shí)現(xiàn)代碼
- PHP封裝返回Ajax字符串和JSON數(shù)組的方法
- php+Ajax處理xml與json格式數(shù)據(jù)的方法示例
相關(guān)文章
php jquery 多文件上傳簡(jiǎn)單實(shí)例
這篇文章主要介紹了php jquery 多文件上傳簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下2013-12-12PHP獲取一年有幾周以及每周開(kāi)始日期和結(jié)束日期
這篇文章主要介紹php計(jì)算一年有多少周,獲取每周開(kāi)始日期和結(jié)束日期,有需要的朋友可以參考一下2015-08-08Laravel使用模型實(shí)現(xiàn)like模糊查詢(xún)的例子
今天小編就為大家分享一篇Laravel使用模型實(shí)現(xiàn)like模糊查詢(xún)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10tp5.1 框架數(shù)據(jù)庫(kù)高級(jí)查詢(xún)技巧實(shí)例總結(jié)
這篇文章主要介紹了tp5.1 框架數(shù)據(jù)庫(kù)高級(jí)查詢(xún)技巧,結(jié)合實(shí)例形式總結(jié)分析了tp5.1 框架數(shù)據(jù)庫(kù)快捷查詢(xún)、區(qū)間查詢(xún)、批量查詢(xún)、閉包查詢(xún)等相關(guān)高級(jí)查詢(xún)使用技巧,需要的朋友可以參考下2020-05-05php利用云片網(wǎng)實(shí)現(xiàn)短信驗(yàn)證碼功能的示例代碼
這篇文章主要介紹了php利用云片網(wǎng)實(shí)現(xiàn)短信驗(yàn)證碼功能的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11php 反斜杠處理函數(shù)addslashes()和stripslashes()實(shí)例詳解
PHP自帶的庫(kù)函數(shù) addslashes() 和 stripslashes() 都屬于字符串處理類(lèi)函數(shù), 本文章向大家介紹php 反斜杠處理函數(shù)addslashes()和stripslashes(),需要的朋友可以參考下2016-12-12php arsort 數(shù)組降序排序詳細(xì)介紹
php arsort函數(shù)用于將數(shù)組中的元素按照降序進(jìn)行排序,如果排序成功則返回true,否則返回false,本文章向大家講解arsort函數(shù)的基本語(yǔ)法及使用實(shí)例,需要的朋友可以參考下2016-11-11php微信公眾平臺(tái)開(kāi)發(fā)之微信群發(fā)信息
這篇文章主要為大家詳細(xì)介紹了php微信公眾平臺(tái)開(kāi)發(fā)之微信群發(fā)信息,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09