javascript与php使用json进行数据通信

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript与php使用json进行数据通信相关的知识,希望对你有一定的参考价值。

  1. javascript
    <script>
    /*
    @desc 加载XHR文件
    @author lee [<[email protected]>]
    @param file 文件路径
    @param async 同步或异步 true 异步 flase 同步
    @return xmlDoc 加载后的内容
    */
    function loadDoc(file,async=true){
    if(window.XMLHttpRequest){  // code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp=new XMLHttpRequest();
    }else{  // code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    if(async === true){
        xmlhttp.onreadystatechange = function(){
            if(xmlhttp.readyState < 4){
                // 加载中
            }else if (xmlhttp.readyState == 4 && xmlhttp.status == 200){
                // 成功
                var xmlDoc
                if(xmlhttp.getResponseHeader(‘content-type‘)===‘application/json‘){
                    xmlDoc = JSON.parse(xmlhttp.responseText);  
                }else{
                    xmlDoc = xmlhttp.responseText
                }
                return xmlDoc
            }else{
                // 失败
                xmlhttp.abort()
                return
            }
        }
    }
    xmlhttp.open("POST",file,async);
    xmlhttp.setRequestHeader("Content-type", "application/json");
    var data = {name:"lee"}
    var str = JSON.stringify(data)
    xmlhttp.send(str);
    if(async === false){
        var xmlDoc
        if(xmlhttp.getResponseHeader(‘content-type‘)===‘application/json‘){
            xmlDoc = JSON.parse(xmlhttp.responseText);  
        }else{
            xmlDoc = xmlhttp.responseText
        }
        return xmlDoc
    }
    }
    var str = loadDoc(‘test.php‘,false)
    console.log(str.name)
    </script>
  2. php:
    <?php
    header("content-type:application/json");
    $json = file_get_contents(‘php://input‘);
    echo $json;

以上是关于javascript与php使用json进行数据通信的主要内容,如果未能解决你的问题,请参考以下文章

javascript与php使用json传递数据

为啥将数据从 php 发送到 javascript (Laravel) 时进行 json 编码?

将 JSON 从 php 传递到 javascript

从 Javascript 获取 JSON 数据

使用 PHP 加载 JSON

使用 Fetch API 将数据发送到 PHP 服务器(首选 POST 方法和 JSON)