opauthのTwitterでログインできない際の対応方法
2024/02/20
opauthを使ったソーシャルログインのシステムにてTwitterでログインできなくなっていた。
「Callback URL not approved for this client application. Approved callback URLs can be adjusted in your application settings.」とエラー内容が表示されており、調べたところTwitter側のAPIの仕様変更らしく他所でも複数報告が見られた。
ただ、opauthをしており尚且つアプリではなくWebページでの記事がなかったので対応策が中々分からなかった。以下に対応方法をメモ。
対応方法
上記ページからログインして利用中のAppを選択し、Settingsタブを開く。Callback URLsを入れる。URLは「http://hoge.com/login/」で実装している場合は、
http://hoge.com/login/twitter/oauth_callback
を入力しUpdate Settingsボタンを押して設定を反映させると解決する。
その他
CallbackのURLを設定するというのはエラー内容から分かるんだけど、実際にURLをどう書けばよいのか分からなかった。以下辺りを試したが解決されなかった。
- http://hoge.com/login/
- http://hoge.com/login/index.php
- http://hoge.com/login/callback.php
- http://hoge.com/login/twitter
なのでopauthの「/login/lib/Opauth/Strategy/Twitter/TwitterStrategy.php」内にある、
'oauth_callback' => '{complete_url_to_strategy}oauth_callback',
の中身を見たところ「http://hoge.com/login/twitter/oauth_callback」が正解だった。
無いとは思うけどopauthのバージョン違いとかで上記で対応できない場合は、71行目あたりで以下を追記することでcallback用のURLが見られる。
public function request(){
$params = array(
'oauth_callback' => $this->strategy['oauth_callback']
);
var_dump($params); //これを追記
$results = $this->_request('POST', $this->strategy['request_token_url'], $params);
if ($results !== false && !empty($results['oauth_token']) && !empty($results['oauth_token_secret'])){
session_start();
$_SESSION['_opauth_twitter'] = $results;
$this->_authorize($results['oauth_token']);
}
}
関連記事
-
-
FLASHがインストールされているかどうかチェックする
以前にここでちょっとやったけど、インストールされているか どうかだけならもっと良 ...
-
-
$_SERVER['PHP_SELF']に脆弱性あり
formのaction属性とかページングのリンクとかで、 <form ac ...
-
-
PHPで他サーバにHTTP経由にてファイルをアップロードする方法
formで画像を送信した後、他サーバにファイルをアップロードしたかった。以前はP ...
-
-
MySQLとPHPの「image-comparator」ライブラリを使用して類似画像検索を実装する方法
先日PHPで画像を比較して類似度を算出する「image-comparator」ラ ...
-
-
CentOSでPHPを5.5から5.3にバージョンダウンする方法
事情があってVPSに入れているPHPを5.5系から5.3系にバージョンダウンした ...