使用Laravel Socialite登录Facebook更新 2018 - laravel 5.6 - 社交名流 3.0服务器端脸书方面重要提示

然而,我是Laravel的新手,我正在按照 http://www.codeanchor.net/blog/complete-laravel-socialite-tutorial/ 教程,通过Facebook将用户登录到我的应用程序中。但是,几乎在任何地方我都可以找到使用Github或Twitter的教程,用于Laravel中提供的Socialite插件。

我的问题是,在遵循本教程中的所有内容时,当我单击“登录到Facebook”按钮时,它会抛出一个“无效参数异常”,其中没有指定Socialite驱动程序。

另一个堆栈溢出问题似乎缩小了范围:https://stackoverflow.com/questions/29673898/laravel-socialite-invalidargumentexception-in-socialitemanager-php-line-138-n

指出问题出在配置/服务中.php

现在,我有app_id和app_secret。但是,重定向链接似乎令人困惑,因为我在Facebook上也找不到它。我知道这是我的应用程序应该去Facebook登录的地方,但是,不确定它应该是什么。

有没有人对此有任何想法。


答案 1

在您的 composer.json 中添加-"laravel/socialite": "~2.0",

"require": {
        "laravel/framework": "5.0.*",
        "laravel/socialite": "~2.0",

运行composer update

配置/服务中.php添加:

//Socialite
    'facebook' => [
        'client_id'     => '1234567890444',
        'client_secret' => '1aa2af333336fffvvvffffvff',
        'redirect'      => 'http://laravel.dev/login/callback/facebook',
    ],

您需要创建两条路线,我的路线如下:

//Social Login
Route::get('/login/{provider?}',[
    'uses' => 'AuthController@getSocialAuth',
    'as'   => 'auth.getSocialAuth'
]);


Route::get('/login/callback/{provider?}',[
    'uses' => 'AuthController@getSocialAuthCallback',
    'as'   => 'auth.getSocialAuthCallback'
]);

您还需要为上述路由创建控制器,如下所示:

<?php namespace App\Http\Controllers;

 use Laravel\Socialite\Contracts\Factory as Socialite;

 class AuthController extends Controller
 {

       public function __construct(Socialite $socialite){
           $this->socialite = $socialite;
       }


       public function getSocialAuth($provider=null)
       {
           if(!config("services.$provider")) abort('404'); //just to handle providers that doesn't exist

           return $this->socialite->with($provider)->redirect();
       }


       public function getSocialAuthCallback($provider=null)
       {
          if($user = $this->socialite->with($provider)->user()){
             dd($user);
          }else{
             return 'something went wrong';
          }
       }

 }

最后将网站URL添加到您的Facebook应用程序,如下所示:

enter image description here


答案 2

更新 2018 - laravel 5.6 - 社交名流 3.0

对于看起来/应该很容易的东西来说,这有点棘手,但无论如何,这就是我让事情为我工作的方式。

服务器端

您可以在社交网站文档中找到这些说明和更多详细信息

安装

composer require laravel/socialite

配置

配置/服务中.php添加

'facebook' => [

    'client_id'     => env('FACEBOOK_CLIENT_ID'),
    'client_secret' => env('FACEBOOK_CLIENT_SECRET'),
    'redirect'      => env('FACEBOOK_CALLBACK_URL'),
],

.env 文件中添加

FACEBOOK_CLIENT_ID=paste_client_id_here
FACEBOOK_CLIENT_SECRET=paste_client_secret_here
FACEBOOK_CALLBACK_URL=https://www.example.com/auth/facebook/callback

路由/网络中.php添加

Route::get('auth/facebook/', 'Auth\FacebookController@redirect')->name('auth.facebook');

Route::get('auth/facebook/callback', 'Auth\FacebookController@callback')->name('auth.facebook.callback');

App\Http\Controllers\Auth 中添加新的控制器 FacebookController.php

<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use App\User;
use Socialite;

class FacebookController extends Controller {

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function redirect()
    {
        return Socialite::driver('facebook')->redirect();
    }


    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function callback(Request $request)
    {
        try {

            $facebookAccount = Socialite::driver('facebook')->user();

            // your logic here...

            return redirect()->route('your.route.name');


        } catch (Exception $e) {


            return redirect()->route('auth.facebook');
        }
    }
}

脸书方面

转到 https://developers.facebook.com/apps 并创建新应用程序(如果您还没有应用程序)

并使您的应用程序设置如下,这些屏幕截图如下:

enter image description here

enter image description here

重要提示

如果您在本地机器中进行开发,则必须使用像ngrok这样的工具,这些工具提供指向本地主机的安全链接。

在Facebook登录设置中,使用ngrok提供的url更改 https://www.example.com,例如 https://8b0215bc.ngrok.io

这是在我的本地机器上进行开发时对我有用的唯一方法。


推荐