Laravel 5.6 с социальным входом в Facebook - PullRequest
0 голосов
/ 19 сентября 2018

Я пытаюсь сделать логин через фейсбук, используя социальные сети.Я зарегистрировался на developers.facebook.com и получил свои APP_ID и Secret_code, и я реализовал их в своем файле .env и config / services.php.Но когда после того, как я ввел свое имя пользователя и пароль в Facebook, он не может направить меня на домашнюю страницу.Я использовал аутентификационные леса от laravel

Ошибка

This site can't be reach

LoginController.php

<?php

 namespace App\Http\Controllers\Auth;
 use App\User;
 use Socialite;
 use Auth;
 use App\Http\Controllers\Controller;
 use Illuminate\Foundation\Auth\AuthenticatesUsers;


 class LoginController extends Controller
{
/*
|--------------------------------------------------------------------------
| Login Controller
|--------------------------------------------------------------------------
|
| This controller handles authenticating users for the application and
| redirecting them to your home screen. The controller uses a trait
| to conveniently provide its functionality to your applications.
|
*/

use AuthenticatesUsers;

/**
 * Where to redirect users after login.
 *
 * @var string
 */
protected $redirectTo = '/home';

/**
 * Create a new controller instance.
 *
 * @return void
 */
public function __construct()
{
    $this->middleware('guest')->except('logout');
}

public function redirectToProvider($provider)
{
    return Socialite::driver($provider)->redirect();
}

/**
 * Obtain the user information from provider.  Check if the user already exists in our
 * database by looking up their provider_id in the database.
 * If the user exists, log them in. Otherwise, create a new user then log them in. After that
 * redirect them to the authenticated users homepage.
 *
 * @return Response
 */
public function handleProviderCallback($provider)
{
    $user = Socialite::driver($provider)->user();
    $authUser = $this->findOrCreateUser($user, $provider);
    Auth::login($authUser, true);
    return redirect($this->redirectTo);
}

/**
 * If a user has registered before using social auth, return the user
 * else, create a new user object.
 * @param  $user Socialite user object
 * @param $provider Social auth provider
 * @return  User
 */
public function findOrCreateUser($user, $provider)
{
    $authUser = User::where('provider_id', $user->id)->first();
    if ($authUser) {
        return $authUser;
    }
    return User::create([
        'name'     => $user->name,
        'email'    => $user->email,
        'provider' => $provider,
        'provider_id' => $user->id
    ]);
}
  }

.env

FB_ID=321**14684*****
FB_SECRET=40fb4782*****5b7b88391f4599f18c7
FB_URL=https://localhost:8000/auth/facebook/callback

web.php

Route::get('/', function () {
return view('homepage');
});

Auth::routes();

Route::get('/home', 'HomeController@index')->name('home');
Route::get('auth/{provider}', 'Auth\LoginController@redirectToProvider');
Route::get('auth/{provider}/callback', 
'Auth\LoginController@handleProviderCallback');

**App\User.php**
<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;

 class User extends Authenticatable
 {
use Notifiable;

/**
 * The attributes that are mass assignable.
 *
 * @var array
 */
protected $fillable = [
    'name', 'email', 'password','provider','provider_id'
];

/**
 * The attributes that should be hidden for arrays.
 *
 * @var array
 */
protected $hidden = [
    'password', 'remember_token',
];
 }

Config / services.php

        'facebook' => [
        'client_id'     => env('FB_ID'),
        'client_secret' => env('FB_SECRET'),
        'redirect'      => env('FB_URL'),
        ],

Пожалуйста, дайте мне несколько советов, чтобы решить эту проблему.Я извиняюсь за мой плохой английский.Спасибо.

...