zoukankan      html  css  js  c++  java
  • Ajax中的JSON格式与php传输过程的浅析

    原文作者:aircraft

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

     

     

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

     

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

    HTML文件:

    <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方法请求数据,所以这时候还要加上一个请求文件头

    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文件里的代码:
    <?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()函数将其识别为一个空的代码块

     

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

     

     

     


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

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

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

    转发和使用本文,请注明作者信息和原文地址---本文原作者为aircraft ---大家好我是徐飞机,有没有大佬们的公司招c++开发/图像处理/opengl/opencv/halcon实习的啊,带上我一个呗QAQ。。。hhhhhh 想要免费获取前端,后端,c/c++,matlab,Python,opencv,机器学习,深度学习,安卓,java,等等全套视频教程请关注机器视觉开发公众号,转发集赞28即可百度云获得hhhhhhhh
  • 相关阅读:
    页面通过Ajax异步生成的添加按钮增加事件
    本地浏览器访问虚拟机上tomcat失败
    Android 6.0 动态申请 音频+拍照+相册 权限
    TouTiao开源项目 分析笔记6
    TouTiao开源项目 分析笔记5
    TouTiao开源项目 分析笔记4==>一个简单APP 整体常用框架
    TouTiao开源项目 分析笔记3
    TouTiao开源项目 分析笔记2
    Wind Of Change
    TouTiao开源项目 分析笔记1
  • 原文地址:https://www.cnblogs.com/DOMLX/p/7831820.html
Copyright © 2011-2022 走看看