所以我试图从bit.ly中检索access_token以使用他们的url缩短API调用。每次我进行curl调用时,我都会获得INVALID_CLIENT_ID作为响应。我检查了四倍,所有的钥匙都很好。可能会发生什么?
以下是代码:
define('BITLY_CLIENT_ID','xxx');
define('BITLY_CLIENT_SECRET','xxx');
define('BITLY_API_KEY','xxx');
function curl($url, $params) {
$params_str = http_build_query($params);
$curl = curl_init();
$header[0] = "Accept: text/xml,application/xml,application/xhtml+xml,";
$header[0] .= "text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5";
$header[] = "Cache-Control: max-age=0";
$header[] = "Connection: keep-alive";
$header[] = "Keep-Alive: 300";
$header[] = "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7";
$header[] = "Accept-Language: en-us,en;q=0.5";
$header[] = "Pragma: "; // browsers keep this blank.
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
curl_setopt($curl, CURLOPT_POST,count($params));
curl_setopt($curl, CURLOPT_POSTFIELDS,urlencode($params_str));
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$rs = curl_exec($curl);
curl_close($curl);
return $rs;
}
$access_token = curl('https://api-ssl.bitly.com/oauth/access_token',array('client_id'=>BITLY_CLIENT_ID,'client_secret'=>BITLY_CLIENT_SECRET,'x_auth_username'=>'MY_USERNAME','x_auth_password'=>'MY_PASSWORD'));
echo $access_token;exit; // Returns INVALID_CLIENT_ID
答案 0 :(得分:2)
来自API documentation:必须通过电子邮件api@bitly.com请求通过XAuth进行身份验证
这可能是原因吗?
另外,urlencoding整个$ params_str看起来很可疑。
答案 1 :(得分:1)
所以我今天早些时候通过电子邮件发送了Bit.ly(很棒的服务顺便说一下,快速而有礼貌),这是他们给我的回复:
如果您要做的就是为自己的帐户获取access_token,我建议使用http://dev.bitly.com/authentication.html中记录的基本身份验证机制。只需加载终端并使用您的用户名和密码卷曲以下网址:
curl -u“用户名:密码”-X POST“https://api-ssl.bitly.com/oauth/access_token”
所以运行此命令并将access_token复制并粘贴到配置中。
我的新卷曲电话看起来像这样:
curl('https://api-ssl.bitly.com/v3/shorten',array('apiKey'=>BITLY_API_KEY,'access_token'=>BITLY_ACCESS_TOKEN,'longUrl'=>'http://www.google.com'))
P.S - urlencoding $ params_str也打破了电话。谢谢你们!