2

我将 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'=>'text/xml' 并给出相同的错误。我已经验证了 xml,并且我知道访问令牌很好,因为我可以很好地使用它们来发出 GET 请求。

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

4

1 回答 1

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);
于 2011-06-04T05:22:50.760 回答