質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

OAuth

OAuth(Open Authorization)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

Twitter

Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

0回答

1093閲覧

FlaskでTweepyを使用してTL取得、ツイート

rm11_j

総合スコア4

Flask

FlaskはPython用のマイクロフレームワークであり、Werkzeug・Jinja 2・good intentionsをベースにしています。

OAuth

OAuth(Open Authorization)は、APIを通して保護されたリソース(サードパーティのアプリケーション)へアクセスする為のオープンプロトコルです。

Twitter

Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2021/10/22 12:28

twitterのoauth認証について質問です。
今python(flask)を用いたwebページを作成しています。
そのページのホームには、Twitterのある特定のハッシュタグで検索をした場合のタイムラインが表示されており、さらに[このページをシェア]をクリックすると、現在開いているページのURLがツイートされてTwitterで共有できるという機能を実装しようとしています。
まずTwitterのタイムラインを表示するために、tweepyというライブラリを使い、タイムラインを取得しています。そのために、開発用アカウントとしてアクセストークンを取得(developer toolから)してapiオブジェクトを作成し、表示できました。

auth = tweepy.OAuthHandler(CONSUMER_KEY, CONSUMER_SECRET, callback_url) auth.set_access_token(ACCESS_TOKEN_KEY, ACCESS_TOKEN_SECRET)

しかし、ページをシェアする場合は開発者用のアカウントではなく、閲覧者のアカウントです。もしも最初のタイムラインを表示する際に使用したapiオブジェクトだと、開発者用アカウントが紐づいたものなので、共有ツイートも開発者用アカウントから行われてしまいます。
従って、apiオブジェクトのアクセストークンを変更すれば良いと考えました。twitterの認証→コールバックURLの処理で閲覧者のアカウントからアクセストークンを取得→新しいapiオブジェクトをセットという形にしました。以下、認証ページで認証した後に遷移されるURL(/auth)の処理です。

auth = tweepy.OAuthHandler(CONSUMER_KEY, CONSUMER_SECRET, callback_url) oauth_token = request.args.get('oauth_token',default=' ',type=str) oauth_verifier = request.args.get('oauth_verifier',default=' ',type=str) auth.request_token['oauth_token'] = oauth_token auth.request_token['oauth_token_secret'] = oauth_verifier auth.get_access_token(oauth_verifier) auth.set_access_token(auth.access_token,auth.access_token_secret) api = tweepy.API(auth)

つまり最初の訪問時は開発者用のアカウントで、共有ツイートをツイートした後(つまりapiオブジェクトに閲覧者のアクセストークンが設定された後)はホーム画面に表示されるツイートの取得は閲覧者のアクセストークンによって行われることを想定していたのですが、エラーが出てしまいました(tweepy.errors.Unauthorized: 401 Unauthorized)。
エラー文から、認証に関するものだと推測はできますが、このようなやり方は無理なのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問