将json对象从javascript发送到php

时间:2014-05-20 03:41:39

标签: javascript php jquery ajax json

我正在尝试将JSON对象从Javascript / Jquery发送到PHP,我在控制台中收到错误信息。我究竟做错了什么。我是JS和PHP的新手。

JQuery文件:

$(document).ready(function() {
    var flickr = {'action': 'Flickr', 'get':'getPublicPhotos'};
    // console.log(typeof(flickr));
    var makeFlickrCall = function(flickrObj){
        $.ajax({
            url: '../phpincl/apiConnect.php',
            type: 'POST',
            data: flickrObj
        })
        .done(function(data) {
            console.log("success");
            console.log(JSON.stringify(data));
        })
        .fail(function() {
            console.log("error");
        })
        .always(function() {
            console.log("complete");
        });
    };

    makeFlickrCall(flickr);
});

PHP文件

<?php       
    $obj = $_POST['data'];
    // print_r($obj);
    return $obj;
?>

3 个答案:

答案 0 :(得分:10)

标准jQuery .ajax()方法使用data属性创建 x-www-form-urlencoded 字符串以传递请求正文。像这样的东西

action=Flickr&get=getPublicPhotos

因此,您的PHP脚本不应该查找$_POST['data'],而是$_POST['action']$_POST['get']

如果要将原始JSON数据有效负载发送到PHP,请执行以下操作...

将AJAX contentType参数设置为application/json,并将{em>字符串化版本的JSON对象作为data有效负载发送,例如

$.ajax({
    url: '../phpincl/apiConnect.php',
    type: 'POST',
    contentType: 'application/json',
    data: JSON.stringify(flickrObj),
    dataType: 'json'
})

然后,您的PHP脚本将从php://input流中读取数据有效负载,例如

$json = file_get_contents('php://input');

然后,您可以将其解析为PHP对象或数组...

$dataObject = json_decode($json);
$dataArray = json_decode($json, true);

并且,如果您只是想将其回复给客户......

header('Content-type: application/json');

// unmodified
echo $json;

// or if you've made changes to say $dataArray
echo json_encode($dataArray);

答案 1 :(得分:5)

菲尔的优秀答案,但是因为OP标题说

  

从javascript(不是jQuery )发送json对象到php

这是如何用(vanilla)javascript做的,以防它有助于某人寻找这种方法:

var jsondata;
var flickr = {'action': 'Flickr', 'get':'getPublicPhotos'};
var data = JSON.stringify(flickr);

var xhr = new XMLHttpRequest();
xhr.open("POST", "../phpincl/apiConnect.php", !0);
xhr.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
xhr.send(data);
xhr.onreadystatechange = function () {
    if (xhr.readyState === 4 && xhr.status === 200) {
        // in case we reply back from server
        jsondata = JSON.parse(xhr.responseText);
        console.log(jsondata);
    }
}

注意我们仍然需要使用JSON.parse()

将服务器的响应转换为javascript 对象

现在,在服务器端(基于Phil的回答)如果您要向客户端发回回复,您可以这样做:

header('Content-type: application/json');
$json = file_get_contents('php://input');
$json_decode = json_decode($json, true); 
$json_encode = json_encode($json_decode);
echo $json_encode;

注意

首先解码然后编码回原始json输入的原因是在数据中的(可能的)URL中正确地转义斜杠,例如

json_encode会转换此网址

http://example.com

http:\/\/example.com

...... OP中不是这种情况,但在其他一些场景中很有用。

答案 2 :(得分:1)

使用:

makeFlickrCall( { data: JSON.stringify( flickr )} );

而不是

makeFlickrCall(flickr);

您的服务器端脚本应该按如下方式接收您的JSON:

data="{"action":"Flickr","get":"getPublicPhotos"}"