2

我正在使用Twitterizer库将网站内的推文发布到我的 Twitter 帐户中。它在现场运行良好,在我的本地服务器上运行(通过 twitter 应用程序使用 OAuth 进行身份验证并发布推文)。但是当我尝试在生产服务器上发布推文时,Twitterizer 说:“结果 =未经授权。错误消息 =无法使用 OAuth 进行身份验证。”

我仔细检查了消费者密钥,还尝试重置密钥并重试 - 结果相同。

Twitter 应用程序具有对我的 Twitter 帐户的读/写访问权限,并且没有被阻止。这个问题在成功工作了大约一个月后突然出现,当时每隔一小时左右就会发布一次推文。

这里有什么问题?

更新 似乎,其他人也面临这个问题:https ://dev.twitter.com/discussions/305

更新 2 最后,我发现了导致问题出现在我的案例中的原因。生产服务器上的 Web 应用程序尝试使用 140 个字符更新状态(由 String.Length 属性测量)。第一个字符是 unicode Character 'LEFT-TO-RIGHT MARK' (U+200E)。因此,此文本被传递给 TwitterStatus.Update(..) 而不做任何更改。我调试了一点 Twitterizer 资源,发现 oauth_signature(=hash) 计算不正确。oauth_signature 是从实际请求的另一个 url 生成的。我还没有清除这个错误发生的原因和时间,可能会在接下来的几天里写更多的信息。

更新 3 我尝试使用新版本的 Twitterizer (2.3.3) 发布相同的消息,但没有发生错误。问题消失了。

这是我用来发布推文的代码:

OAuthTokens tokens = new OAuthTokens();
tokens.AccessToken = ConfigurationManager.AppSettings["twitterAccessToken"];
tokens.AccessTokenSecret = ConfigurationManager.AppSettings["twitterAccessTokenSecret"];
tokens.ConsumerKey = ConfigurationManager.AppSettings["twitterAutoPosterConsumerKey"];
tokens.ConsumerSecret = ConfigurationManager.AppSettings["twitterAutoPosterConsumerSecret"];

string text = "Some text";

TwitterResponse<TwitterStatus> tweetResponse = TwitterStatus.Update(tokens, text);
if (tweetResponse.Result == RequestResult.Success)
{
    // Tweet posted successfully!
    _log.InfoFormat("Posted a tweet #{0}.", tweetResponse.ResponseObject.Id);
}
else
{
    _log.ErrorFormat("Error occured while posting a tweet. Result = {0}. ErrorMessage = {1}",
        tweetResponse.Result, tweetResponse.ErrorMessage);
}
4

2 回答 2

1

请检查消息,如果消息有撇号 (') ,请替换为&amp;#39;

请注意,这&amp;#39;将计为 5 个字符。

我认为撇号会影响发送到 twitter 的请求包,使 twitter 无法正确获取令牌,因此我们将收到错误“无法使用 OAuth 进行身份验证”。

于 2012-02-01T02:23:57.230 回答
0

我有同样的麻烦。PHP 5.3.1 在我的本地服务器上运行,而 PHP 4.3.2 在我的生产服务器上运行。我使用从下面获得的 Google 代码的 OAuth 库,

http://code.google.com/p/oauth/source/browse/#svn%2Fcode%2Fjavascript

我探索了 PHP 代理程序从浏览器上的 javascript 代码接收到的 OAuth 标头。在我的本地服务器上,它是

OAuth realm="",oauth_consumer_key="XXX",oauth_token="XXX",oauth_version="1.0",oauth_timestamp="1314956434",oauth_nonce="mF7Tof",oauth_signature_method="HMAC-SHA1",oauth_signature="DbuaiDeMhMYNZ5BaQmOoFr%2FRsEQ %3D"

而在我的生产服务器上,上面的所有双引号都被转义了,即'\"'。所以我使用str_replace函数将转义的双引号替换为未转义的双引号。然后它在我的生产服务器上运行良好。原因是 PHP 5.3.1 和 PHP 4.3.2 处理双引号的方式不同。转义的双引号导致错误“无法使用 OAuth 进行身份验证”。

于 2011-09-02T10:29:10.553 回答