Socialite не работает в Laravel Middleware. Как я могу решить эту проблему? - PullRequest
2 голосов
/ 26 марта 2020

Я использую Socialite для аутентификации Google, у меня есть промежуточное ПО для проверки того, что если пользователь существует в моей локальной базе данных по его google_id, он может перенаправить на страницу / home , в противном случае он будет перенаправлен обратно на аутентификацию Google страница, при этом я сталкиваюсь с проблемой в середине, и ошибка:

Ошибка клиента: POST https://www.googleapis.com/oauth2/v4/token привел к ответу 400 Bad Request: {"error": "invalid_request", "error_description ":" Отсутствует обязательный параметр: код "}

Промежуточное программное обеспечение

<?php

namespace App\Http\Middleware;
//use Socialite;
use App\GmailAccount;
use Closure;

use Laravel\Socialite\Facades\Socialite;

use Illuminate\Support\Facades\Auth;

class GoogleAuth
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {

        $user = Socialite::driver('google')->stateless()->user();

        $finduser = GmailAccount::where('google_id', $user->id)->first();

        if($finduser){
            return $next($request);
        }

        else{
            return route('/logingoogle');
        }

    }
}

Маршруты

Route::group(['middleware' => 'App\Http\Middleware\GoogleAuth'], function()
{
    Route::get('/home', 'HomeController@index')->name('home');

});

Route::get('/logingoogle', 'GoogleController@google_login');

Route::get('auth/google', 'GoogleController@redirectToGoogle');

Route::get('auth/google/callback', 'GoogleController@handleGoogleCallback');

HomeController

class HomeController extends Controller
{
    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('auth');

        $this->middleware('googleauth');
    }

    /**
     * Show the application dashboard.
     *
     * @return \Illuminate\Contracts\Support\Renderable
     */
    public function index()
    {
        $user_id=Auth::user()->id;
        $user_messages=DB::table('user_message')
            ->join('messages', 'user_message.message_id', '=', 'messages.id')
            ->where([
            'user_message.user_id' => $user_id,
            'user_message.placeholder' => 'inbox'
                ])
            ->select('messages.*', 'user_message.message_id', 'user_message.user_id','user_message.is_read')
            ->orderBy('messages.id', 'DESC')

            ->paginate(10);
        return view('website_pages.home',compact('user_messages'));
    }
}

GoogleController

class GoogleController extends Controller
{
    /**
     * Create a new controller instance.
     *
     * @return void
     */

    public function __construct()
    {
        $this->middleware('auth');
    }

    public function google_login(){

        return  view('website_pages.login_google');

    }

    public function redirectToGoogle()
    {
        return Socialite::driver('google')->stateless()->redirect();
    }

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function handleGoogleCallback()
    {

            $login_user_id  =  Auth::user()->id;

        try {

            $user = Socialite::driver('google')->stateless()->user();

            $finduser = GmailAccount::where('google_id', $user->id)->first();

            if($finduser){
                return redirect('/home');
            }
            else{
                $newUser = DB::table('gmail_accounts')->updateOrInsert(
                    [
                        'email' => $user->email,
                    ],

                    [
                    'user_id' => $login_user_id,
                     'email' => $user->email,
                    'google_id'=> $user->id,
                    'remember_token'=> $user->token
                ]

                );

                if ($newUser){
                    return redirect('/home');
                }

                else{
                    return redirect()->back();
                }
                Auth::login($newUser, true);
            }

        } catch (Exception $e) {
            dd($e->getMessage());
        }
    }
}

GmailAccount Модель

class GmailAccount extends Model
{
    protected $table = 'gmail_accounts';


    protected $fillable = [
       'email', 'password', 'google_id', 'user_id', 'remember_token'
    ];


    public function user()
    {
        return $this->belongsTo('App\User');
    }
}

Ответы [ 3 ]

1 голос
/ 26 марта 2020

Можете ли вы попробовать это?

if($finduser) {
    auth()->login($finduser), true);
}
else {
    return redirect('/logingoogle');
}
0 голосов
/ 26 марта 2020

Следуйте этому, который является рабочим примером:

<?php

namespace App\Http\Controllers\Auth;

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

class LoginController extends Controller
{
    use AuthenticatesUsers;

    public function redirectToProvider()
    {
        return Socialite::driver('google')->redirect();
    }

    public function handleProviderCallback()
    {
        try {
            $user = Socialite::driver('google')->user();
        } catch (\Exception $e) {
            return redirect('/login');
        }

        // check if they're an existing user
        $existingUser = User::where('email', $user->email)->first();

        if ($existingUser) {
            // log them in
            auth()->login($existingUser, true);
        } else {
            // create a new user
            $newUser                  = new User;
            $newUser->name            = $user->name;
            $newUser->email           = $user->email;
            $newUser->google_id       = $user->id;
            $newUser->avatar          = $user->avatar;
            $newUser->avatar_original = $user->avatar_original;
            $newUser->lastlogin_at    = \Carbon\Carbon::now();
            $newUser->save();
            auth()->login($newUser, true);
        }
        session(['user_name' => $user->name]);
        session(['user_email' => $user->email]);
        session(['user_avatar' => $user->avatar]);

        return redirect()->to('/home');
    }
}
Route::get('/redirect', 'Auth\LoginController@redirectToProvider');
Route::get('/callback', 'Auth\LoginController@handleProviderCallback');
0 голосов
/ 26 марта 2020

И включите их:

use Illuminate\Foundation\Auth\AuthenticatesUsers; use Socialite;

...