57

我正在使用 CURL 发送请求。响应数据类型是json。如何解析这些数据并将其插入数据库?

<?php

$url = 'http://sms2.cdyne.com/sms.svc/SimpleSMSsendWithPostback?        PhoneNumber=18887477474&Message=test&LicenseKey=LICENSEKEY';

$cURL = curl_init();

curl_setopt($cURL, CURLOPT_URL, $url);
curl_setopt($cURL, CURLOPT_HTTPGET, true);

curl_setopt($cURL, CURLOPT_HTTPHEADER, array(
    'Content-Type: application/json',
    'Accept: application/json'
));

$result = curl_exec($cURL);

curl_close($cURL);



print_r($result);

?>

JSON输出:

{
    "Cancelled": false,
    "MessageID": "402f481b-c420-481f-b129-7b2d8ce7cf0a",
    "Queued": false,
    "SMSError": 2,
    "SMSIncomingMessages": null,
    "Sent": false,
    "SentDateTime": "/Date(-62135578800000-0500)/"
}
4

3 回答 3

100

如果您的$result变量是类似 json 的字符串,则必须使用json_decode函数将其解析为对象数组

$result = '{"Cancelled":false,"MessageID":"402f481b-c420-481f-b129-7b2d8ce7cf0a","Queued":false,"SMSError":2,"SMSIncomingMessages":null,"Sent":false,"SentDateTime":"\/Date(-62135578800000-0500)\/"}';
$json = json_decode($result, true);
print_r($json);

输出

Array
(
    [Cancelled] => 
    [MessageID] => 402f481b-c420-481f-b129-7b2d8ce7cf0a
    [Queued] => 
    [SMSError] => 2
    [SMSIncomingMessages] => 
    [Sent] => 
    [SentDateTime] => /Date(-62135578800000-0500)/
)

现在您可以将$json变量用作数组:

echo $json['MessageID'];
echo $json['SMSError'];
// other stuff

参考:

于 2013-06-10T03:34:02.217 回答
12

您的示例代码的主要问题是$result您用于存储输出的变量curl_exec()不包含 HTTP 响应的主体 - 它包含值true。如果您尝试print_r()这样做,它只会说“1”。

参考curl_exec()解释

返回值

TRUE成功或FALSE失败返回。但是,如果CURLOPT_RETURNTRANSFER设置了该选项,它将在成功时返回结果,FALSE在失败时返回。

因此,如果您想在$result变量中获取 HTTP 响应正文,您必须首先运行

curl_setopt($cURL, CURLOPT_RETURNTRANSFER, true);

之后,您可以调用json_decode()$result正如其他答案所指出的那样。

一般而言 - PHP 的 curl 库很有用,并且有很多功能可以处理 HTTP 协议(​​和其他协议)的细节,但如果你想要的只是GET一些资源甚至POST是一些 URL,并阅读响应 -那么file_get_contents()这就是你所需要的:它使用起来更简单,而且不用担心令人惊讶的行为。

于 2019-12-12T10:16:27.200 回答
9

尝试:

$result = curl_exec($cURL);
$result = json_decode($result,true);

现在您可以MessageID$result['MessageID'].

至于数据库,它只是使用这样的查询:

INSERT INTO `tableName`(`Cancelled`,`Queued`,`SMSError`,`SMSIncommingMessage`,`Sent`,`SentDateTime`) VALUES('?','?','?','?','?');

准备好了。

于 2013-06-10T03:30:39.870 回答