使用PECL OAuth通过REST API使用PHP邀请请求

时间:2011-06-03 20:59:57

标签: php oauth linkedin pecl

我正在使用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请求。

任何帮助将不胜感激,谢谢。

1 个答案:

答案 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);