Ajax中的JSON格式与php传输过程全面解析


Posted in PHP onNovember 14, 2017

在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");这是固定写法直接记下来就可以了。<br><br>上面的是测试代码,创建一个json格式的字符串并用SEND方法传入PHP:

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这一块的代码

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

* 使用eval()函数进行转换
         使用"()"将其包裹,eval()函数强制将其转换为JSON格式(javascript代码)
         不使用"()"将其包裹,eval()函数将其识别为一个空的代码块

总结

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

PHP 相关文章推荐
php fsockopen中多线程问题的解决办法[翻译]
Nov 09 PHP
PHP中array_merge和array相加的区别分析
Jun 17 PHP
PHP 文件编程综合案例-文件上传的实现
Jul 03 PHP
详解WordPress中提醒安装插件以及隐藏插件的功能实现
Dec 25 PHP
PHP中的Trait 特性及作用
Apr 03 PHP
PHP实现截取中文字符串不出现?号的解决方法
Dec 29 PHP
详解php用curl调用接口方法,get和post两种方式
Jan 13 PHP
浅谈PHP发送HTTP请求的几种方式
Jul 25 PHP
php基于环形链表解决约瑟夫环问题示例
Nov 07 PHP
php+croppic.js实现剪切上传图片功能
Aug 14 PHP
thinkPHP5.1框架路由::get、post请求简单用法示例
May 06 PHP
基于php伪静态的实现方法解析
Jul 31 PHP
PHP基于imagick扩展实现合成图片的两种方法【附imagick扩展下载】
Nov 14 #PHP
Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解
Nov 14 #PHP
PHP中递归的实现实例详解
Nov 14 #PHP
利用Homestead快速运行一个Laravel项目的方法详解
Nov 14 #PHP
PHP对称加密算法(DES/AES)类的实现代码
Nov 14 #PHP
浅谈PHP中如何实现Hook机制
Nov 14 #PHP
PHP实现将几张照片拼接到一起的合成图片功能【便于整体打印输出】
Nov 14 #PHP
You might like
Zend Studio使用技巧两则
2016/04/01 PHP
PHP6连接SQLServer2005的三部曲
2016/04/15 PHP
PHP 在数组中搜索给定的简单实例 array_search 函数
2016/06/13 PHP
PHP registerXPathNamespace()函数讲解
2019/02/03 PHP
laravel框架中路由设置,路由参数和路由命名实例分析
2019/11/23 PHP
prototype 源码中文说明之 prototype.js
2006/09/22 Javascript
基于jQuery的获得各种控件Value的方法
2010/11/19 Javascript
js鼠标滑轮滚动事件绑定的简单实例(兼容主流浏览器)
2014/01/14 Javascript
如何使用Bootstrap的modal组件自定义alert,confirm和modal对话框
2016/03/01 Javascript
js多功能分页组件layPage使用方法详解
2016/05/19 Javascript
javascript弹出窗口中增加确定取消按钮
2016/06/24 Javascript
Bootstrap.css与layDate日期选择样式起冲突的解决办法
2017/04/07 Javascript
json2.js 入门教程之使用方法与实例分析
2017/09/14 Javascript
JS实现按钮添加背景音乐示例代码
2017/10/17 Javascript
webpack4+react多页面架构的实现
2018/10/25 Javascript
JavaScript变速动画函数封装添加任意多个属性
2019/04/03 Javascript
AntV F2和vue-cli构建移动端可视化视图过程详解
2019/10/08 Javascript
VUE单页面切换动画代码(全网最好的切换效果)
2019/10/31 Javascript
js中apply和call的理解与使用方法
2019/11/27 Javascript
vue组件开发之slider组件使用详解
2020/08/21 Javascript
vue-cli3项目打包后自动化部署到服务器的方法
2020/09/16 Javascript
介绍Python中的一些高级编程技巧
2015/04/02 Python
Python中列表元素转为数字的方法分析
2016/06/14 Python
python笔记:mysql、redis操作方法
2017/06/28 Python
Python简单实现查找一个字符串中最长不重复子串的方法
2018/03/26 Python
python中pip的安装与使用教程
2018/08/10 Python
python列表插入append(), extend(), insert()用法详解
2019/09/14 Python
python多线程实现代码(模拟银行服务操作流程)
2020/01/13 Python
解决pycharm不能自动补全第三方库的函数和属性问题
2020/03/12 Python
Python Tornado批量上传图片并显示功能
2020/03/26 Python
美国性感内衣店:Yandy
2018/06/12 全球购物
幼儿教师师德师风演讲稿
2014/08/22 职场文书
八项规定个人对照检查材料思想汇报
2014/09/25 职场文书
成本会计实训报告
2014/11/05 职场文书
会计岗位职责
2015/02/03 职场文书
聊聊基于pytorch实现Resnet对本地数据集的训练问题
2022/03/25 Python