尝试请求令牌时出现 Twitter API 错误
Posted
技术标签:
【中文标题】尝试请求令牌时出现 Twitter API 错误【英文标题】:Twitter API error when trying to request a token 【发布时间】:2021-11-04 00:20:09 【问题描述】:我正在尝试使用 twitter api 端点为用户获取访问令牌的第一步。但 request_token 端点不工作,我得到一个通用的 500 内部服务器错误。这是我要达到的端点:
POST https://api.twitter.com/oauth/request_token?oauth_callback=http%3A%2F%2example.com%2Fapi%2Ftwitter%2Foauth
Authorization: OAuth oauth_nonce="kYjzVBB8Y0ZFabxSWbWovY3uYSQ2pTgmZeNu2VS4cg", oauth_callback="http%3A%2F%2example.com%2Fapi%2Ftwitter%2Foauth", oauth_signature_method="HMAC-SHA1", oauth_timestamp="1630988166522", oauth_consumer_key="<MY_CONSUMER_KEY>", oauth_signature="8cVT5tNumrTit77OZkiaA1fSo7Y=", oauth_version="1.0"
User-Agent: PostmanRuntime/7.28.4
Accept: */*
Postman-Token: 449c980f-eb74-41f4-a747-1fe1bd34c755
Host: api.twitter.com
Accept-Encoding: gzip, deflate, br
Connection: keep-alive
Cookie: guest_id=v1%3A163090645168923415; personalization_id="v1_Enx+SO8Z5+LYLTsALKSDtg=="
Content-Length: 0
HTTP/1.1 500 Internal Server Error
x-connection-hash: e6046252ae2e0f7ade3b81bd3e3aa9377e83fe0f48a686d03e14260f1f3599b6
date: Tue, 07 Sep 2021 04:16:03 GMT
server: tsa_b
content-length: 0
回调是 http://
回调也在我的 Twitter 应用设置中定义......
oauth_signature 是使用以下 javascript 创建的:
function createSignature()
var str =
"include_entities=true" +
"&oauth_callback=" + "http%3A%2F%2example.com%2Fapi%2Ftwitter%2Foauth" +
"&oauth_consumer_key=" + "<MY_CONSUMER_KEY>" +
"&oauth_nonce=kYjzVBB8Y0ZFabxSWbWovY3uYSQ2pTgmZeNu2VS4cg" +
"&oauth_signature_method=HMAC-SHA1" +
"&oauth_timestamp=" + Date.now() +
"&oauth_token=" + "<MY_APP_AUTH_ACCESS_TOKEN>" +
"&oauth_version=1.0"
;
var signature_base_string =
"POST" +
"&https%3A%2F%2Fapi.twitter.com%2F1.1%2Foauth%2Frequest_token" +
"&" + encodeURIComponent(str);
var signing_key =
"<MY_CONSUMER_SECRET>" +
"&" +
"<MY_APP_AUTH_ACCESS_SECRET>";
var hash = CryptoJS.HmacSHA1(signature_base_string, signing_key);
var base64 = hash.toString(CryptoJS.enc.Base64);
return base64;
我错过了什么??
谢谢!
【问题讨论】:
【参考方案1】:我想通了。我在生成签名时遗漏了一些信息。应该是这样的:
var CryptoJS = require("crypto-js");
function createSignature()
var str =
"oauth_callback=" + encodeURIComponent("<MY_CALLBACK_URL>") +
"&oauth_consumer_key=" + "<CONSUMER_KEY>" +
"&oauth_nonce=kYjzVBB8Y0ZFabxSWbWovY3uYSQ2pTgmZeNu2VS4cg" +
"&oauth_signature_method=HMAC-SHA1" +
"&oauth_timestamp=" + Math.floor((new Date()).getTime() / 1000) +
"&oauth_token=" + "<TWITTER_ACCESS_TOKEN>" +
"&oauth_version=1.0"
;
var signature_base_string =
"POST" +
"&" + encodeURIComponent("https://api.twitter.com/oauth/request_token") +
"&" + encodeURIComponent(str);
var signing_key =
"<CONSUMER_SECRET>" +
"&" +
"<TOKEN_SECRET>";
var hash = CryptoJS.HmacSHA1(signature_base_string, signing_key);
return encodeURIComponent(hash.toString(CryptoJS.enc.Base64));
其他一切都是正确的......
谢谢!
【讨论】:
以上是关于尝试请求令牌时出现 Twitter API 错误的主要内容,如果未能解决你的问题,请参考以下文章
使用 twitter 登录 Quickblox 时出现错误的身份验证数据错误
在 rest api 中发布请求时出现 415 错误,尝试运行 cms 查询
使用来自 Angular JS 的 Web API 令牌身份验证时出现错误请求 (400)
使用 Tweepy 检索 Twitter 数据时出现 401 错误