ajax请求php保存数据格式,Ajax中的JSON格式与php传输过程全面解析

本文详细介绍了在Ajax中使用JSON格式与PHP进行数据传输的过程。重点包括设置请求头、构建JSON字符串、PHP的json_decode和json_encode函数的使用。强调了在构建JSON字符串时引号的正确使用,以及在JavaScript中如何通过eval()函数将接收到的文本数据转换为JSON格式。
摘要由CSDN通过智能技术生成

在Ajax中的JSON格式与php传输过程中有哪些要注意的小地方呢?

先来看一下简单通用的JSON与php传输数据的代码

HTML文件:

var btn = document.getElementById("btn");

btn.onclick = function(){

var xhr = getXhr();

xhr.open("post","测试.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;

}

在整个过程中先要获得AJAX对象,然后用POST请求方式与PHP文件连接,这时候用的是POST方法请求数据,所以这时候还要加上一个请求文件头

xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");这是固定写法直接记下来就可以了。
上面的是测试代码,创建一个json格式的字符串并用SEND方法传入PHP:

var user = '{"name":"zhangwuji","pwd":"123456"}';

xhr.send("user="+user);
这时候要注意了,在构建JSON字符串传输的时候user里面的字符串外面要用单引,里面用双引,不然php那边是不认为你这是JSON 不能正确的进行解析。
这时候看看PHP文件里的代码:

// 接收客户端发送的请求数据

$user = $_POST['user'];

// 就是一个JSON格式的string字符串

$json_user = json_decode($user,true);//对json格式的字符串进行解码,转换成PHP变量格式

// 2. 使用json_encode()函数

echo json_encode($json_user);//对php变量格式进行编码,转换成JSON格式

?>

json_decode 和json_encode大家从字面的意思都应该可以看出来一点,decode在这这里的作用就是

对json格式的字符串进行解码,转换成PHP变量格式

而encode就是

对php变量格式进行编码,转换成JSON格式在传输回去;

这时候PHP 文件的工作已经结束了,让我们在回到HTML文件看接受数据的onreadystatechange这一块的代码

var data = xhr.responseText;  虽然PHP文件传输回来的是一个JSON格式,但是我们这里接受用的是respenseText所以接收到的只是一个文本格式的字符串
这时候我们还要用eval();函数将其转换成JSON格式

* 使用eval()函数进行转换

使用"()"将其包裹,eval()函数强制将其转换为JSON格式(javascript代码)

不使用"()"将其包裹,eval()函数将其识别为一个空的代码块

总结

以上所述是小编给大家介绍的Ajax中的JSON格式与php传输过程全面解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值