javascript - 如何在 Google Apps 脚本上为 Reddit 请求访问令牌
问题描述
我一直在试图弄清楚如何从Google Apps 脚本中的Reddit API获取访问令牌。到目前为止,我编写了以下代码:
function main() {
var username = 'myredditusername';
var pwd = 'myredditpassword';
var client_id = 'myredditclientid';
var client_secret = 'myredditclientsecret';
var access_token_url = 'https://www.reddit.com/api/v1/access_token';
var api_url = 'https://oauth.reddit.com/';
var user_agent = 'MySideProjectUserAgent';
var data = {
'grant_type': 'password',
'username': username,
'password': pwd
};
var options = {
'method' : 'post',
'contentType': 'application/json',
'payload' : JSON.stringify(data),
'headers': {'User-Agent': user_agent},
// what do I enter here to pass my client_id and client_secret?
};
var resp = UrlFetchApp.fetch(access_token_url, options);
console.log(resp.getContentText());
}
运行上面的代码会收到如下错误(这并不奇怪,因为我仍然需要弄清楚如何传入我的client_id
and client_secret
):
Exception: Request failed for https://www.reddit.com returned code 401. Truncated server response: {"message": "Unauthorized", "error": 401} (use muteHttpExceptions option to examine full response)
使用时curl
,我能够使用以下命令成功获取令牌:
curl -X POST -A 'KeywordTrackAgent' -d "grant_type=password&username=myredditusername&password=myredditpassword" --user 'client_id:client_secret' https://www.reddit.com/api/v1/access_token
从到达(示例帖子)开始,我想如果我要将此curl
请求转换为POST
请求,我需要使用如下格式Authorization
向我的参数添加字段:headers
function main() {
var username = 'myredditusername';
var pwd = 'myredditpassword';
var client_id = 'myredditclientid';
var client_secret = 'myredditclientsecret';
var access_token_url = 'https://www.reddit.com/api/v1/access_token';
var api_url = 'https://oauth.reddit.com/';
var user_agent = 'MySideProjectUserAgent';
var data = {
'grant_type': 'password',
'username': username,
'password': pwd
};
var options = {
'method' : 'post',
'contentType': 'application/json',
'payload' : JSON.stringify(data),
'headers': {
'User-Agent': user_agent,
// Below, I decided to encode my client_id and client_secret in base64 with the prefix 'Basic '
'Authorization': 'Basic clientIdAndClientSecretInBase64',
},
};
var resp = UrlFetchApp.fetch(access_token_url, options);
console.log(JSON.parse(resp.getContentText()));
}
我仍然收到{错误:'unsupported_grant_type'}。
任何人——已经使用 JavaScript 并且最好是使用 Google Apps 脚本成功获取 Reddit 访问令牌的人——可以分享一些建议/见解吗?预先感谢您的回答!
解决方案
我相信你的目标如下。
您想将以下 curl 命令转换为 Google Apps 脚本。
curl -X POST -A 'KeywordTrackAgent' -d "grant_type=password&username=myredditusername&password=myredditpassword" --user 'client_id:client_secret' https://www.reddit.com/api/v1/access_token
此 curl 命令将数据作为表单数据发送。并且,使用基本授权。当这些反映到 Google Apps Script 时,它变成如下。
示例脚本:
在此脚本中,使用您的值。
function main() {
var username = 'myredditusername';
var pwd = 'myredditpassword';
var client_id = 'myredditclientid';
var client_secret = 'myredditclientsecret';
var access_token_url = 'https://www.reddit.com/api/v1/access_token';
var data = {
'grant_type': 'password',
'username': username,
'password': pwd
};
var options = {
'method': 'post',
'payload': data,
'headers': {
'Authorization': 'Basic ' + Utilities.base64Encode(`${client_id}:${client_secret}`),
},
};
var resp = UrlFetchApp.fetch(access_token_url, options);
console.log(JSON.parse(resp.getContentText()));
}
- 在此脚本中,请求与 curl 命令相同。
笔记:
- 在这个脚本中,它假设授权的值是正确的。请注意这一点。
参考:
推荐阅读
- wagtail - 如何将页面隐私复制到 Wagtail 中的 Block?
- batch-file - 如何使用批处理脚本删除特定文件夹中的所有文件
- r - 当艺术家名称不起作用时,使用来自 spotifyr 的 get_artist_audio_features
- javascript - 如何手动将 Linking.getInitialUrl 设置为空
- php - 更新我的证书后出现 SMTP 错误(SSL3_GET_SERVER_CERTIFICATE:证书验证失败)
- javascript - MongoDb 更新到数组
- ramda.js - Ramda 从数组内的嵌套对象中获取值
- reactjs - 离子标签栏更改 URL 但未呈现页面
- shell - 如何将参数传递给Dockerfile中的shellscript
- python - 使用 flasgger 库在 Python 中 Swagger 更改基本 URL