Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/250.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php Bit.ly访问令牌无效\u客户端\u ID_Php_Api_Curl_Bit.ly - Fatal编程技术网

Php Bit.ly访问令牌无效\u客户端\u ID

Php Bit.ly访问令牌无效\u客户端\u ID,php,api,curl,bit.ly,Php,Api,Curl,Bit.ly,因此,我试图从bit.ly检索一个访问令牌,以使用他们的url缩短API调用。每次调用curl时,我都会得到无效的客户ID作为响应。我检查了四次,所有的钥匙都没问题。会发生什么 代码如下: define('BITLY_CLIENT_ID','xxx'); define('BITLY_CLIENT_SECRET','xxx'); define('BITLY_API_KEY','xxx'); function curl($url, $params) { $params_str = htt

因此,我试图从bit.ly检索一个访问令牌,以使用他们的url缩短API调用。每次调用curl时,我都会得到无效的客户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
发件人:必须通过电子邮件请求通过XAuth进行身份验证api@bitly.com

这可能是原因吗

此外,整个$params_str的URL编码看起来可疑。

发件人:必须通过电子邮件请求通过XAuth进行身份验证api@bitly.com

这可能是原因吗


另外,整个$params_str看起来很可疑。

所以我今天早些时候发了一封电子邮件(非常棒的服务,顺便说一句,快速而礼貌),这是他们给我的回复:

如果您希望做的只是为自己的帐户获取一个访问令牌,我建议使用中介绍的基本身份验证机制。只需加载终端并使用您的用户名和密码创建以下URL:

curl-u“用户名:密码”-X POSThttps://api-ssl.bitly.com/oauth/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-url编码$params_str也破坏了通话。谢谢timoh

所以我今天早些时候发了一封电子邮件(非常棒的服务,顺便说一句,快速而礼貌),这是他们给我的回复:

如果您希望做的只是为自己的帐户获取一个访问令牌,我建议使用中介绍的基本身份验证机制。只需加载终端并使用您的用户名和密码创建以下URL:

curl-u“用户名:密码”-X POSThttps://api-ssl.bitly.com/oauth/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-url编码$params_str也破坏了通话。谢谢timoh