twitter - 尝试请求令牌时出现 Twitter API 错误
问题描述
我正在尝试使用 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://<example.com>/api/twitter/oauth
我在 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;
}
我错过了什么?
谢谢!
解决方案
我想通了。我在生成签名时遗漏了一些信息。应该是这样的:
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));
}
其他一切都是正确的...
谢谢!
推荐阅读
- spring-boot - 无法部署我的第一个 Azure Spring Cloud 应用程序
- node.js - Date-fns 格式化日期?
- javascript - 强制自动导入在 TypeScript Visual Studio 代码编辑器中使用“.js”扩展名
- python - 当 __init__ 将数组作为参数时 Python 的 __repr__ 方法
- c# - 有没有一种简单的方法可以在其他类方法中使用 2 个不同的类
- r - dplyr:summary_at 中的自定义函数
- javascript - 错误 - 无法读取 null 的属性“toLowerCase”
- python - 如何使用套接字在 Python 中处理多人游戏中的数据
- r - 在 for 循环中出现 tryCatch 错误“找不到对象”
- angular - 如何使用 Angular 8+ 从控制器检查 Ionic 框架中的选择框选项?