firebase - Twitter OAuth request_token:错误代码 32,无法进行身份验证
问题描述
我正在尝试在我的 Game Maker 应用程序中通过 OAuth 和 Twitter 向 Firebase 验证用户身份(Game Maker 不支持 SDK)。
通过 REST HTTP POST 请求(根据https://developer.twitter.com/en/docs/basics/authentication/api-reference/request_token)执行此操作,但响应为“错误 32,无法对您进行身份验证”。
我已经在 Firebase 和 Twitter 的开发者控制台上设置了我的应用程序,并将 API 密钥/秘密值复制到了 Firebase 控制台。Firebase 为我提供了一个 callback_url,我已将其列入 Twitter 应用程序的白名单。
我正在关注 3-legged OAuth 的 Twitter API 文档(这是第 1 步,POST request_token),并检查了无穷无尽的其他资源。
在签名上,我用在线编码器仔细检查了我的 HMAC-SHA1 编码是正确的,它是正确的。
这是我的 HTTP 请求:
网址:https ://api.twitter.com/oauth/request_token 方法:POST 标头:
Host : api.twitter.com,
Content-Type : application/x-www-form-urlencoded,
Authorization :
Oauth oauth_callback="https%3A%2F%2Fbitblock-blast.firebaseapp.com%2F__%2Fauth%2Fhandler", oauth_consumer_key="kEH9VascQh5rGdq6khl0oCfnL", oauth_nonce="p0B7y4w0P334qa633JzF370z89LK0N60", oauth_signature="MTIwMjc1Nzc1MTczODQ1OTUxMzQyMzgxMzIxNzYxODQxMjQyMzkyNTEyMDI3MTI0MjM1", oauth_signature_method="HMAC-SHA1", oauth_timestamp="1571857067", oauth_version="1.0"
身体: ””
标头的签名是从此字典生成的:
oauth_callback : https://bitblock-blast.firebaseapp.com/__/auth/handler,
oauth_consumer_key : [TWITTER API KEY],
oauth_nonce : [NONCE],
oauth_signature_method : "HMAC-SHA1",
oauth_timestamp" : [TIMESTAMP],
oauth_version" : "1.0"
(所有值都由各自的脚本填写)
这就是我创建最终签名字符串的方式:
var parameters = map_to_http_parameter_string(header); //Convert to "key=value, key=value" format
var signature_base = string_upper(method) + "&" + percent_encode(url) + "&" + percent_encode(parameters);
var signing_key = [TWITTER_API_SECRET] + "&";
var signature = base64_encode(string_hex_to_binary(hash_hmac(signature_base, signing_key)));
以下是签名创建的分步细分:
Concatenated 'parameters' string: "oauth_callback=https%3A%2F%2Fbitblock-blast.firebaseapp.com%2F__%2Fauth%2Fhandler&oauth_consumer_key=[API_KEY]&oauth_nonce=5sR6w60Hz2Uvk10EdW5135O79NuV3y7b&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1571857990&oauth_version=1.0" (As you can see these已排序和百分比编码)
串联的“基本签名”字符串:“POST&https%3A%2F%2Fapi.twitter.com%2Foauth%2Frequest_token&oauth_callback%3Dhttps%253A%252F%252Fbitblock-blast.firebaseapp.com%252F__%252Fauth%252Fhandler%26oauth_consumer_key%3D[API_key] %26oauth_nonce%3D5sR6w60Hz2Uvk10EdW5135O79NuV3y7b%26oauth_signature_method%3DHMAC-SHA1%26oauth_timestamp%3D1571857990%26oauth_version%3D1.0"
签名密钥“[TWITTER_API_SECRET]&”(访问密码留空)
在(基本签名,签名密钥)上运行 HMAC-SHA1,编码为 base64(十六进制转二进制部分是必要的,因为 Game Maker 中的 HMAC-SHA1 生成十六进制 ASCII 字符串)
最后,我将该签名添加到标头的 Authentication 值并发送我的 HTTP 请求。
响应应该是 OAuth 令牌,而不是我不断收到错误 32,无法对您进行身份验证。
我已经检查了所有内容以查看我做错了什么,但找不到。
解决方案
好的,我发现这是一个愚蠢的错字:我在授权标头中写了“Oauth oauth_callback ...”而不是“OAuth oauth_callback ...”。
推荐阅读
- mysql - 通过sql脚本自动分配任务
- oracle - 如何在不使用 to_date、trunc 和预定义的 add_months 函数的情况下获取上个月的第一个和最后一个日期
- sql - 使用左连接或联合在值之间进行选择
- function - Common Lisp - 从数字列表构建更多、小于或等于给定数字的列表的函数
- python - 一种随机选择带有一些噪声的集合的顶部元素的算法
- javascript - firebase登录密码错误
- mysql - 用wordpress设置mysql
- python - 识别 HTTP 请求中的参数
- python - 注释掉“for”语句导致 'NoneType' 没有 len()
- vb.net - 带有响应的 HttpWebRequest