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

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

新規登録して質問してみよう
ただいま回答率
85.48%
OAuth 2.0

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

Twitter

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

2212閲覧

【PHP】Twitter Oauth2.0を利用したログインがうまくいかない

KUBO3

総合スコア18

OAuth 2.0

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

Twitter

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2022/05/09 12:07

PHPでTwitter Oauth2.0を利用したログインの実装で、「Authorize app」クリック後、callback URLに遷移すると下記のようなエラーが出ます。

{"error":"invalid_request","error_description":"Missing required parameter [grant_type]."}int(1)

ソースコードは下記です。どのようにすればうまくいくか、わかる方いたら教えていただけると助かります。

login.php

PHP

1<?php 2 session_start(); 3 4 define('Consumer_Key', '<Consumer Key>'); 5 define('Consumer_Secret', 'Consumer Secret'); 6 define('Callback', 'http://127.0.0.1:3000/callback.php'); 7 define('Client_id', 'Client ID'); 8 9 $base_url = 'https://twitter.com/i/oauth2/authorize'; 10 11 $query = [ 12 'response_type' => 'code', 13 'client_id' => Client_id, 14 'redirect_uri' => Callback, 15 'scope' => 'tweet.read users.read offline.access', 16 'state' => 'state', 17 'code_challenge' => 'codeChallenge', 18 'code_challenge_method' => 'S256' 19 ]; 20 21 $url = $base_url . '?' . http_build_query($query); 22 23 header('Location: ' . $url); 24 25?> 26

callback.php

PHP

1<?php 2 session_start(); 3 4 define('Consumer_Key', 'Consumer Key'); 5 define('Consumer_Secret', 'Consumer Secret'); 6 define('Callback', 'http://127.0.0.1:3000/callback.php'); 7 define('Client_id', 'Client ID'); 8 define('Client_Secret', 'Client Secret'); 9 10 $base_url = 'https://api.twitter.com/2/oauth2/token'; 11 $user_creds = Consumer_Key.':'.Consumer_Secret; 12 $client = Client_id.':'.Client_Secret; 13 $authorization_code = $_GET['code']; 14 15 $header = array( 16 "Authorization: Basic " . $client, 17 "Content-Type: application/x-ww-form-urlencoded", 18 ); 19 20 $data = array( 21 "grant_type" => "client_credentials", 22 "client_id" => Client_id, 23 "client_secret" => Client_Secret, 24 "code" => $authorization_code, 25 "redirect_uri" => Callback, 26 "code_verifier" => "challenge", 27 ); 28 29 $curl = curl_init(); 30 31 curl_setopt($curl, CURLOPT_URL, $base_url); 32 curl_setopt($curl, CURLOPT_HTTPHEADER, $header); 33 curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($data)); 34 35 $response = curl_exec($curl); 36 $result = json_decode($response, true); 37 38 curl_close($curl); 39 40 var_dump($result); 41 42?> 43

●参考にしていたURL
https://zenn.dev/kg0r0/articles/8b1cfe654a1cee
https://developer.twitter.com/en/docs/authentication/oauth-2-0/authorization-code

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

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

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

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

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

guest

回答1

0

PHP v7.4.18の環境で以下のコードでアクセストークンとリフレッシュトークンを取得できました

PHP

1 $code = htmlspecialchars($_GET["code"]); 2 $client_id = config('twitterToken.client_id'); 3 $client_secret = config('twitterToken.client_secret'); 4 5 $client_key = rawurldecode($client_id); 6 $client_secret = rawurldecode($client_secret); 7 8 $base64_key = base64_encode($client_key.':'.$client_secret); 9 10 $url = 'https://api.twitter.com/2/oauth2/token?code='.$code.'&grant_type=authorization_code&client_id='.$client_id.'&redirect_uri=http://127.0.0.1:8000/OAuthCallback&code_verifier=challenge'; 11 12 $curl = curl_init(); 13 curl_setopt_array($curl, array( 14 CURLOPT_URL => $url, 15 CURLOPT_RETURNTRANSFER => true, 16 CURLOPT_CUSTOMREQUEST => "POST", 17 CURLOPT_HTTPHEADER => array( 18 "authorization: Basic ".$base64_key, 19 "cache-control: no-cache", 20 "content-type: application/x-www-form-urlencoded" 21 ), 22 )); 23 24 $tokenResponse = curl_exec($curl); 25 $err = curl_error($curl); 26 27 curl_close($curl); 28

投稿2022/10/04 15:03

ttpk

総合スコア338

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問