アプリケーションのみの認証を使用して Twitter 1.1 検索エンドポイントにアクセスしたいと考えています。同じことを行うために、ここで Twitter API のドキュメントに記載されている手順を実装しようとしています - https://dev.twitter.com/docs/auth/application-only-auth (「Issuing application-only requests」までスクロールします)
ステップ 2 で「ベアラー トークン」を取得できません。次のコードを実行すると、場所へのリダイレクトである「Response: 302 Found」を受け取ります: 理想的には「200 OK」であるべきです。
import urllib
import base64
import httplib
CONSUMER_KEY = 'my_key'
CONSUMER_SECRET = 'my_secret'
encoded_CONSUMER_KEY = urllib.quote(CONSUMER_KEY)
encoded_CONSUMER_SECRET = urllib.quote(CONSUMER_SECRET)
concat_consumer_url = encoded_CONSUMER_KEY + ":" + encoded_CONSUMER_SECRET
host = 'api.twitter.com'
url = '/oauth2/token'
params = urllib.urlencode({'grant_type' : 'client_credentials'})
req = httplib.HTTP(host)
req.putrequest("POST", url)
req.putheader("Host", host)
req.putheader("User-Agent", "My Twitter 1.1")
req.putheader("Authorization", "Basic %s" % base64.b64encode(concat_consumer_url))
req.putheader("Content-Type" ,"application/x-www-form-urlencoded;charset=UTF-8")
req.putheader("Content-Length", "29")
req.putheader("Accept-Encoding", "gzip")
req.endheaders()
req.send(params)
# get the response
statuscode, statusmessage, header = req.getreply()
print "Response: ", statuscode, statusmessage
print "Headers: ", header
これにアクセスするために Twitter API ラッパーを使用したくありません。