Ajax中的JSON格式与php传输过程的浅析

原文作者:aircraft

原文地址:https://www.cnblogs.com/DOMLX/p/7831820.html

 

 

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

 

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

HTML文件:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<input type="button" value="Ajax" id="btn">
  <script>
    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;
    }
  </script>

 

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

1
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");这是固定写法直接记下来就可以了。<br><br>上面的是测试代码,创建一个json格式的字符串并用SEND方法传入PHP:
1
2
var user = '{"name":"zhangwuji","pwd":"123456"}';
        xhr.send("user="+user);<br><br>这时候要注意了,在构建JSON字符串传输的时候user里面的字符串外面要用单引,里面用双引,不然php那边是不认为你这是JSON 不能正确的进行解析。<br><br><br>这时候看看PHP文件里的代码:
复制代码
<?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这一块的代码
1
var data = xhr.responseText;   虽然PHP文件传输回来的是一个JSON格式,但是我们这里接受用的是respenseText所以接收到的只是一个文本格式的字符串<br>这时候我们还要用eval();函数将其转换成JSON格式
1
2
3
* 使用eval()函数进行转换
                 使用"()"将其包裹,eval()函数强制将其转换为JSON格式(javascript代码)
                  不使用"()"将其包裹,eval()函数将其识别为一个空的代码块

 

 也可以看看数据库与PHP 连接的博客http://www.cnblogs.com/DOMLX/p/8116845.html

 

 

 


大家好我是飞机,是一个想成为全栈工程师的男人。

https://www.cnblogs.com/DOMLX/p/7831820.html

若有兴趣交流分享技术,可关注本人公众号,里面会不定期的分享各种编程教程,和共享源码,诸如研究分享关于c/c++,python,前端,后端,opencv,halcon,opengl,机器学习深度学习之类有关于基础编程,图像处理和机器视觉开发的知识

posted @   aircraft  阅读(1034)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下
点击右上角即可分享
微信分享提示