我正在使用PECL OAuth与LinkedIn,因为它与Twitter和LinkedIn的GET请求一起正常工作。如果无法运行,将切换到LinkedIn自己的OAuth库,但更愿意通过相同的OAuth库执行所有操作。
代码:
$xmlString = "<?xml version='1.0' encoding='UTF-8'?>".
"<mailbox-item>".
"<recipients>".
"<recipient>".
"<person path=\"/people/email={$person->PersonEmail}\">".
"<first-name>{$person->PersonFirstName}</first-name>".
"<last-name>{$person->PersonLastName}</last-name>".
"</person>".
"</recipient>".
"</recipients>".
"<subject>Invitation to Connect</subject>".
"<body>Please join my professional network on LinkedIn.</body>".
"<item-content>".
"<invitation-request>".
"<connect-type>friend</connect-type>".
"</invitation-request>".
"</item-content>".
"</mailbox-item>";
try {
$oauth = new OAuth(self::$apiKey, self::$secretKey, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_FORM);
$oauth->setToken($accessToken, $accessTokenSecret);
$oauth->fetch("http://api.linkedin.com/v1/people/~/mailbox", $xmlString, OAUTH_HTTP_METHOD_POST, array('Content-Type'=>'text/xml'));
$result = $oauth->getLastResponse();
return $result;
} catch (OAuthException $e) {
var_dump($e);
throw new ModelException('Error - Invalid Access Token', ModelException::$excodes['invalid_access_token']);
}
这会抛出一个被捕获的异常,并且var_dump会大量吐出,主要是:“无效的身份验证/错误请求(获得401,预期的HTTP / 1.1 20X或重定向)”
我尝试了很多代码变体。例如,删除'Content-Type'=&gt;'text / xml'并提供相同的错误。我已经验证了xml,我知道访问令牌是好的,因为我正好使用它们来发出GET请求。
任何帮助将不胜感激,谢谢。
答案 0 :(得分:1)
找到解决方案,它正在取代
$oauth = new OAuth(self::$apiKey, self::$secretKey, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_FORM);
与
$oauth = new OAuth(self::$apiKey, self::$secretKey, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_AUTHORIZATION);