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生成静态页面分析 模板+缓存+写文件
Aug 17 PHP
php快速url重写 更新版[需php 5.30以上]
Apr 20 PHP
THINKPHP2.0到3.0有哪些改进之处
Jan 04 PHP
php获取当月最后一天函数分享
Feb 02 PHP
YII视图整合kindeditor扩展的方法
Jul 13 PHP
thinkphp 字母函数详解T/I/N/D/M/A/R/U
Apr 03 PHP
PHP中的正则表达式实例详解
Apr 25 PHP
三个思路解决laravel上传文件报错:413 Request Entity Too Large问题
Nov 13 PHP
Laravel框架实现修改登录和注册接口数据返回格式的方法
Aug 17 PHP
PHP实现微信申请退款功能
Oct 01 PHP
PHP基于swoole多进程操作示例
Aug 12 PHP
tp5框架基于ajax实现异步删除图片的方法示例
Feb 10 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
汉字转化为拼音(php版)
2006/10/09 PHP
Http 1.1 Etag 与 Last-Modified提高php效率
2008/01/10 PHP
php session 检测和注销
2009/03/16 PHP
php中mysql连接方式PDO使用详解
2015/02/25 PHP
PHP共享内存用法实例分析
2016/02/12 PHP
ThinkPHP5.0框架控制器继承基类和自定义类示例
2018/05/25 PHP
JavaScript RegExp方法获取地址栏参数(面向对象)
2009/03/10 Javascript
js parsefloat parseint 转换函数
2010/01/21 Javascript
JavaScript入门之事件、cookie、定时等
2011/10/21 Javascript
jQuery实现带动画效果的二级下拉导航方法
2015/03/11 Javascript
jQuery+html5+css3实现圆角无刷新表单带输入验证功能代码
2015/08/21 Javascript
javascript伸缩型菜单实现代码
2015/11/16 Javascript
jQuery实现宽屏图片轮播实例教程
2015/11/24 Javascript
jQuery插件实现多级联动菜单效果
2015/12/01 Javascript
jQuery EasyUI中DataGird动态生成列的方法
2016/04/05 Javascript
bootstrap-wysiwyg结合ajax实现图片上传实时刷新功能
2016/05/27 Javascript
解析javascript图片懒加载与预加载的分析总结
2016/10/27 Javascript
JS作用域闭包、预解释和this关键字综合实例解析
2016/12/16 Javascript
NodeJS学习笔记之Module的简介
2017/03/24 NodeJs
javascript匿名函数中的'return function()'作用
2018/10/15 Javascript
JS实现简单打字测试
2020/06/24 Javascript
微信小程序实现文件预览
2020/10/22 Javascript
python3使用urllib示例取googletranslate(谷歌翻译)
2014/01/23 Python
Python语言的12个基础知识点小结
2014/07/10 Python
Python基于回溯法子集树模板解决数字组合问题实例
2017/09/02 Python
Python与R语言的简要对比
2017/11/14 Python
python3+requests接口自动化session操作方法
2018/10/13 Python
python 模拟贷款卡号生成规则过程解析
2019/08/30 Python
Python 实现将数组/矩阵转换成Image类
2020/01/09 Python
python 连续不等式语法糖实例
2020/04/15 Python
澳大利亚在线购买儿童玩具:Toy Universe
2017/12/28 全球购物
Stella McCartney官网:成衣、包袋、香水、内衣、童装及Adidas系列
2018/12/20 全球购物
Strathberry苏贝瑞中国官网:西班牙高级工匠手工打造
2020/10/19 全球购物
网络销售员岗位职责
2015/04/11 职场文书
python3实现无权最短路径的方法
2021/05/12 Python
Golang Elasticsearches 批量修改查询及发送MQ
2022/04/19 Golang