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

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

ただいまの
回答率

90.10%

Laravelで作成したWebサイトにFacebook認証を入れたいがエラーが出てしまう

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,660

前提・実現したいこと

laravelで作成したWebサイトにFacebook認証を入れたいと考えています。
やりたいのは、
「Facebook登録」ボタンをクリックするとFacebookの認証画面が出てきて、「○○でログイン」ボタンをクリックするとTOPにリダイレクトする、といったよくあるやつです。

今回はLaravelの拡張パッケージであるSocialiteを使って実現しようとしています。

発生している問題・エラーメッセージ

http://qiita.com/zaburo/items/6f7c072795e99fd98a75
こちらのサイトを参考に、
・facebookアプリの作成
・socialiteのインストール
・configへの追記
・.envへのfacebook_id等の追記
・Routeの記述
・controllerの記述
を行った上でfacebookログインボタンをクリックすると以下のエラーメッセージが発生します。
(多少コードは変えていますので以下のソースコードを参考にして下さい)

また、開発環境はcloud9を利用しています。

Client error: `POST https://graph.facebook.com/oauth/access_token` resulted in a `400 Bad Request` response:
{"error":{"message":"Missing redirect_uri parameter.","type":"OAuthException","code":191,"fbtrace_id":"xxxxxxxxxxxx"}}

該当のソースコード

Cntroller

<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\Http\Requests;
use Laravel\Socialite\Contracts\Factory as Socialite;

class SocialController extends Controller
{

    protected $socialite;

    public function __construct(Socialite $socialite){
        $this->socialite = $socialite;
    }
     /**
     * Redirect the user to the Facebook authentication page.
     * (Facebook認証のページにリダイレクトする)
     * @return Response(レスポンスを返す)
     */
    public function getFacebookAuth(){
        return $this->socialite->driver('facebook')
                    ->with([
                        'app_id' => 123456789,
                        'redirect_uri' => 'https://xxxx-xxxxx.c9users.io/auth/login/callback/facebook'
                        ])
                    ->redirect();
    }

     /**
     * Obtain the user information from Facebook.
     * (facebookのユーザー情報を入手する)
     * @return Response
     */
    public function getFacebookAuthCallback(){
        try{
            $fuser = $this->socialite->driver('facebook')->user();
        }catch(\Exception $e){
            //このエラーメッセージが表示されている
            var_dump($e);
            exit();
        }
        if($fuser){
            //とりあえず$fuserを表示
            dd($fuser);
        }else{
            return "something went wrong";
        }
    }


}

config/app.php

<?php
//providers
Laravel\Socialite\SocialiteServiceProvider::class,

//providers
'Socialite' => Laravel\Socialite\Facades\Socialite::class,

config/services.php

'facebook' => [
    'client_id'     => env('FACEBOOK_ID'),
    'client_secret' => env('FACEBOOK_SECRET'),
    'redirect'      => env('FACEBOOK_CALLBACKURL'),
],

.env

FACEBOOK_ID=123456789
FACEBOOK_SECRET=xxxxxxxxxxxxxxxxxx
FACEBOOK_CALLBACKURL=https://xxxx-xxxxx.c9users.io/auth/login/callback/facebook

Route

Route::get('auth/login/facebook','Auth\SocialController@getFacebookAuth');
Route::get('auth/login/callback/facebook','Auth\SocialController@getFacebookAuthCallback');

ちなみにgetFacebookAuth()with()を使ってapp_idとredirect_uriをパラメータに設定しているのは、これ無しだと、facebook側のエラーで、

The parameter app_id is required


だったり、

The parameter redirect_url is required


が表示されてしまったからです。

ちなみに、Facebookアプリ側での設定は以下の形になります。
(中身は実際のものと変えています)

・アプリID:123456789(.envのFACEBOOK_IDと同様)
・app secret:xxxxxxxxxxxxxxxxxx(.envのFACEBOOK_SECRETと同様)
・有効なOAuthリダイレクトURI:https://xxxx-xxxxx.c9users.io/

また、ログインしようとしたfacebookアカウントはfacebookの管理者アカウントです。

試したこと

検索でSocialiteを使ったFacebook認証のやり方を調べてそれ通りにやってみましたがエラーは解消しませんでした。

エラーの内容的にredirect_uriが無い、みたいなことが書かれているのですが、必要な箇所には設定しているため何が原因なのかわかりませんでした。

補足情報(言語/FW/ツール等のバージョンなど)

開発環境:cloud9
言語:PHP
フレームワーク:laravel5.2
パッケージ:Socialite

追加で必要な情報がございましたら教えていただければと思います。

いろいろ自分でやってみましたがうまくいかなかったので投稿させていただきました。
どうかご助力頂けますと幸いです。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

this->socialite->driver('facebook')
でパラメータが読み込めてないのではないでしょうか?
.envが読み込めてないのか?なんなのかは不明ですが、一旦直記述してみてはいかがでしょうか?

'facebook' => [
    'client_id'     => 12345678,

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/11/27 20:15

    ありがとうございます!
    ご返信が遅くなり申し訳ございません。

    残念ながら上記試しましたが同じエラーでしたので、
    facebookSDK for PHPを使ってやり直してみています。
    ただ、今度は「エラーが発生しました。すみやかに解決できるよう作業しております。」
    というfacebook側のエラー文言が出てきてしまいました。

    ネットで調べてみると1日経ったら戻った、といったコメントがありましたのでひとまず待ってみようと思います。

    このたびはお忙しいところありがとうございました。

    キャンセル

  • 2016/11/27 20:23

    facebook側のエラーだったんですね。

    キャンセル

  • 2016/11/28 01:06

    いえ、socialiteの時のエラーとは異なるエラーのようです。
    ちなみに、先ほどの「エラーが発生しました、、」は解決したのですが、また別のエラーが発生してしまいました。。

    このスレッドで何度も質問させていただくのは申し訳なかったので、新しく質問投稿しています。
    もしお時間ございましたら是非ご協力頂けますと幸いです。
    ↓こちらがURLです。
    https://teratail.com/questions/56780?modal=q-comp

    解決はできていませんが、いろいろとご協力頂いたので、こちらはベストアンサーにさせて頂きます。

    キャンセル

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

  • ただいまの回答率 90.10%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる