gpt4 book ai didi

twitter - 可以通过 twython 使用来自不同帐户的 appkey/secret key 发推文吗?

转载 作者:行者123 更新时间:2023-12-02 00:02:30 25 4
gpt4 key购买 nike

我有一个 Twitter 帐户和一个应用程序,目前它的设置是为了让学生可以从我们的网站发推文,因此他们的推文会在推文底部显示“via SchoolAppNameHere”。

是否可以使用 Twython 来使用 Appkey 和 key ,然后从一个完全不同的地方获取身份验证 token ,所以当我运行下面的代码时,它会从一个没有创建应用程序的帐户发送推文。 ..

from twython import Twython

APP_KEY = ''
APP_SECRET = ''
OAUTH_TOKEN = ''
OAUTH_TOKEN_SECRET = ''

twitter = Twython(APP_KEY, APP_SECRET, OAUTH_TOKEN, OAUTH_TOKEN_SECRET)
twitter.update_status(status="test")

任何想法将不胜感激:)

编辑,更新示例/说明如下:

假设以下图片来自帐户“stackoverflowapp”和名为“Stackoverflow Test App”的应用:

http://i.imgur.com/8sIpak5.png http://i.imgur.com/e6CYt6e.png

使用以下代码会通过名为“Stackoverflow Test App”的应用程序从帐户“stackoverflowapp”发送推文“test”

from twython import Twython

APP_KEY = 'coN_kEY_123456789'
APP_SECRET = 'cOn_sEcr3t_123456789'
OAUTH_TOKEN = 'Acc3ss_tok3N_123456789'
OAUTH_TOKEN_SECRET = 'aCCeSS_tOkEn_sEcrET_123456789'

twitter = Twython(APP_KEY, APP_SECRET, OAUTH_TOKEN, OAUTH_TOKEN_SECRET)
twitter.update_status(status="test")

假设下图来自帐户“useraccount1”,应用名为“testing123”:

http://i.imgur.com/vYJLmfr.png

现在我有了登录帐户“useraccount1”的访问 token ,我如何通过用户创建的名为“Stackoverflow 测试应用程序”的应用程序发送推文:“stackoverflowapp”我尝试的示例如下:

from twython import Twython

APP_KEY = 'coN_kEY_123456789'
APP_SECRET = 'cOn_sEcr3t_123456789'
OAUTH_TOKEN = 'Acc3ss_123456789'
OAUTH_TOKEN_SECRET = 'aCCeSS_sEcrET_123456789'

twitter = Twython(APP_KEY, APP_SECRET, OAUTH_TOKEN, OAUTH_TOKEN_SECRET)
twitter.update_status(status="test update")

不幸的是,我得到了错误:

TwythonAuthError: Twitter API returned a 401 (Unauthorized), Could not authenticate you

最佳答案

这当然是可能的。当您在 Twitter 中创建应用程序时,他们会为您提供自己的身份验证 token ,以供您立即使用,以方便起见。

Use the access token string as your "oauth_token" and the access token secret as your "oauth_token_secret" to sign requests with your own Twitter account. Do not share your oauth_token_secret with anyone.

要为同一应用程序的其他帐户获取 key ,您需要为每个帐户请求更多 key 。此处对此进行了详细描述:https://dev.twitter.com/docs/auth/obtaining-access-tokens

既然听起来像是您要自己进行授权,那么应该使用更简单的 PIN-based 方法。

你正在使用 twython,获取这些可以使用库来完成:https://twython.readthedocs.org/en/latest/usage/starting_out.html#authentication

get_authentication_tokensget_authorized_tokens 是您正在寻找的方法。

from twython import Twython
import sys

APP_KEY = 'coN_kEY_123456789'
APP_SECRET = 'cOn_sEcr3t_123456789'

twitter = Twython( APP_KEY, APP_SECRET )
auth = twitter.get_authentication_tokens()

print( 'Visit %s and enter your PIN: ' % auth.get( 'auth_url' ) ),
pin = sys.stdin.readline().strip()

twitter = Twython( APP_KEY, APP_SECRET, auth.get( 'oauth_token' ), auth.get( 'oauth_token_secret' ) )
tokens = twitter.get_authorized_tokens( pin )

print( 'OAUTH_TOKEN: %s' % tokens.get( 'oauth_token' ) )
print( 'OAUTH_TOKEN_SECRET: %s' % tokens.get( 'oauth_token_secret' ) )

OAUTH_TOKENOAUTH_TOKEN_SECRET 存储在安全的地方并随意重复使用。此外,请确保您在访问 URL 和获取 PIN 时授权了正确的帐户。

您的所有 API 调用都将在通过 token 授权访问的帐户的一半上进行,您的 via 行将是您的原始应用程序。为您要从中发推文的每个帐户使用适当的 token ,这是不可能混合和匹配的。

关于twitter - 可以通过 twython 使用来自不同帐户的 appkey/secret key 发推文吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20450452/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com