如何解决如何在 python 中使用 tweepy 使用承载令牌访问推文?
当我注册 Twitter API for research 时,他们给了我 3 个密钥:API Key、API Secret Key 和 Bearer Token。但是在 Hello Tweepy 示例中,使用了 4 个密钥:consumer_key、consumer_secret、access_token、access_token_secret。显然,前两个键相互映射,但我没有看到consumer_secret 和access_token 如何映射到Bearer Token。我正在使用这个:
CONSUMER_KEY = 'a'
CONSUMER_SECRET = 'b'
ACCESS_TOKEN = 'c'
ACCESS_TOKEN_SECRET = 'd'
BEARER_TOKEN='e'
# Set Connection
auth = tweepy.OAuthHandler(CONSUMER_KEY,CONSUMER_SECRET)
auth.set_access_token(ACCESS_TOKEN,ACCESS_TOKEN_SECRET)
api = tweepy.API(auth,wait_on_rate_limit=True)
我应该在哪里使用不记名令牌? 谢谢
解决方法
很遗憾,目前您将无法使用 Tweepy 访问用于学术研究的全新完整档案搜索端点。他们正在致力于 v2 支持,但现在,您最终会遇到 v1.1 标准搜索 API。
如果您使用 Python,我建议您查看 Twitter 提供的 Twitter API v2 sample code 或 search_tweets client。然后,您可以通过将 BEARER TOKEN 添加为环境变量来使用它,或者如果您更喜欢将其直接添加到代码中,但如果这样做,请注意不要意外将其提交到其他人可能会访问它的源代码控制中.
要回答有关消费者密钥/秘密与访问令牌/秘密与不记名令牌的问题:
- 持有者令牌是根据消费者密钥和秘密授予的,仅代表应用程序身份和凭据
- 访问令牌和秘密代表用户身份。如果您正在使用它们,则不会使用不记名令牌,而是将该对与消费者密钥和秘密结合使用。
在 Tweepy 术语中,AppAuthHandler
会自动检索不记名令牌,在这种情况下不会使用 OAuthHandler
。
您不需要使用不记名密钥。您可以在登录 Twitter 开发者帐户获取密码的部分的不记名密钥下找到您可以使用的访问密钥和机密。
,我认为混淆在于变量的不同术语和这些变量的使用。
下面首先解释,术语澄清,不同的术语指的是同一件事:
客户凭据:
1. App Key === API Key === Consumer API Key === Consumer Key === Customer Key === oauth_consumer_key
2. App Key Secret === API Secret Key === Consumer Secret === Consumer Key === Customer Key === oauth_consumer_secret
3. Callback URL === oauth_callback
临时凭证:
1. Request Token === oauth_token
2. Request Token Secret === oauth_token_secret
3. oauth_verifier
令牌凭据:
1. Access token === Token === resulting oauth_token
2. Access token secret === Token Secret === resulting oauth_token_secret
接下来,使用这些。请注意,bearer Token 代表您的开发者应用程序对请求进行身份验证。由于此方法是针对 App 的,因此不涉及任何用户。 因此,您可以在用户级别或应用级别处理请求,如下所示:
用户级别(OAuth 1.0a):
API key:"hgrthgy2374RTYFTY"
API key secret:"hGDR2Gyr6534tjkht"
Access token:"HYTHTYH65TYhtfhfgkt34"
Access token secret: "ged5654tHFG"
auth = tweepy.OAuthHandler(consumer_key,consumer_secret)
auth.set_access_token(key,secret)
api = tweepy.API(auth)
应用级别(OAuth 2.0):
Bearer token: "ABDsdfj56nhiugd5tkggred"
auth = tweepy.AppAuthHandler(consumer_key,consumer_secret)
api = tweepy.API(auth)
[1] https://developer.twitter.com/en/docs/authentication/oauth-1-0a/obtaining-user-access-tokens
[2] https://docs.tweepy.org/en/latest/auth_tutorial.html
,@ScriptCode
但是仍然不清楚tweepy的OAuthHandler和access_token中的Bearer Token在哪里使用?
位于 https://buildmedia.readthedocs.org/media/pdf/tweepy/latest/tweepy.pdf 的 tweepy 3.10.0 文档说明了 3.3 OAuth 2 身份验证(使用不记名令牌)
auth = tweepy.AppAuthHandler(consumer_key,consumer_secret)
api = tweepy.API(auth)
所以你使用 AppAuthHandler 并且基本上省略了这一步:
auth.set_access_token(key,secret)
当然,您必须确保您已在 Twitter 开发后端中为只读应用注册了不记名令牌。
我试过了,它奏效了......
,来自 Tweepy 文档 (OAuth 2 Authentication)
Tweepy 还支持 OAuth 2 身份验证。 OAuth 2 是一种方法 应用程序在没有身份验证的情况下发出 API 请求的身份验证 用户上下文。如果您只需要只读访问权限,请使用此方法 公开信息。
所以基本上,由于您的应用程序只需要只读访问权限,因此您不需要“访问令牌”和“访问令牌机密”,并且可以忽略第 3 步和第 4 步。此解决方案的简单代码如下:
auth = tweepy.AppAuthHandler(consumer_key,consumer_secret)
api = tweepy.API(auth)
for tweet in tweepy.Cursor(api.search,q='cool').items(3):
print(tweet.text)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。