好的,所以我一直在玩Geckoboard的新数据集 这个(参见前文#1)是文档中的一个例子(我在unix命令行中尝试过,它运行得很好)。但我需要在PHP文件中运行它(我在PHP之前从WooCommerce收集数据)。
Ex#1
curl https://api.geckoboard.com/datasets/sales.gross/data \
-X PUT \
-u '222efc82e7933138077b1c2554439e15:' \
-H 'Content-Type: application/json' \
-d '{
"data": [
{
"timestamp": "2016-01-01T12:00:00Z",
"amount": 819
},
{
"timestamp": "2016-01-02T12:00:00Z",
"amount": 409
},
{
"timestamp": "2016-01-03T12:00:00Z",
"amount": 164
}
]
}'
我试过这个
/*****************
*
* GECKOBOARD
*
*****************/
// API URL
$url = 'https://api.geckoboard.com/datasets/sales.[DATA_SET_NAME]/data';
$key = '[MY_API_KEY]';
$data_array = array(
'net' => $weeklynet,
'timestamp' => date('Y-m-d h:m:s')
);
// create a new cURL resource
$ch = curl_init();
// set URL and other appropriate options
$options = array(
CURLOPT_URL => $url,
CURLOPT_PUT => 1,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_HTTPHEADER => array(
'Content-Type: application/json',
'Authorization', 'OAuth ' . $key
),
CURLOPT_POSTFIELDS => $data_array
);
curl_setopt_array($ch, $options);
// grab URL and pass it to the browser
curl_exec($ch);
// close cURL resource, and free up system resources
curl_close($ch);
但没有任何反应。我不会精通cURL与PHP(或者根本不是)。是否有人可以帮助我将命令行cURL“翻译”为“正确”的PHP版本?此外,不确定日期是否正确输出,它必须采用格式 YYYY-MM-DDTHH:MM:SSZ
感谢任何帮助!
答案 0 :(得分:2)
好的,经过整晚的搜索和测试后,我终于找到了一个有效的解决方案。我不知道为什么我在第一时间获得411,但事实证明,删除
CURLOPT_PUT => 1
并将其替换为
CURLOPT_CUSTOMREQUEST => 'PUT'
至少让我发送数据。然后我得到了401(错误请求)。这只是因为身份验证的传递方式。所以我不得不删除
'Authorization', 'OAuth ' . $key
来自标题数组,而不是使用
CURLOPT_USERPWD => $key . ': '
这样我就从geckoboard传递API密钥(作为用户),密码为空(用户名:密码)。
然后出现了一系列其他问题,但我终于得到了这个工作:)
PS。谢谢@Chris试图帮忙!始终同样对stackoverflow社区的一般帮助感到惊讶。
答案 1 :(得分:0)
将curl_exec()命令分配给变量并查看它返回的内容。
$content = curl_exec($ch);
$headers = curl_getinfo($ch);
curl_close($ch);
if($headers['http_code'] < 400){
/* Do stuff as needed starting with perhaps:
echo "<pre>";
print_r($content); */
}
查看curl here上的php手册。