Laravel 개발: Laravel Socialite와 Google을 사용하여 타사 로그인을 구현하는 방법은 무엇입니까?
최신 웹 애플리케이션에서는 사용자 로그인과 인증이 필수적입니다. 사용자 이름과 비밀번호를 기반으로 하는 기존 인증 방법은 더 이상 보안 및 편의성 요구 사항을 충족할 수 없습니다. 타사 로그인은 사용자가 다른 플랫폼에서 이미 생성한 계정을 사용하여 애플리케이션에 로그인할 수 있도록 하여 이 문제를 해결합니다.
이 글에서는 Laravel Socialite와 Google을 사용하여 타사 로그인을 구현하는 방법을 소개하겠습니다.
라라벨 소셜라이트란 무엇인가요?
Laravel Socialite는 Laravel 커뮤니티에서 널리 사용되는 OAuth 인증 프로세스를 위한 패키징 라이브러리입니다. 이를 통해 Facebook, Twitter, Google 등과 같은 여러 제3자 서비스에 쉽게 연결할 수 있습니다.
Google 개발 플랫폼 설정
먼저 Google 개발 플랫폼에서 OAuth 클라이언트 ID를 생성해야 합니다. https://console.developers.google.com/을 열고 새 프로젝트를 만듭니다. 왼쪽 상단 모서리에 있는 "프로젝트 선택" 드롭다운 메뉴에서 "새 프로젝트"를 클릭합니다.
프로젝트 이름과 기타 프로젝트 설정 정보를 입력하세요. 프로젝트를 생성하면 프로젝트 개요 페이지로 리디렉션됩니다. 상단 메뉴에서 API 및 서비스 > 자격 증명을 선택합니다.
"자격 증명 만들기" 버튼을 클릭하고 "OAuth 클라이언트 ID"를 선택하세요.
"애플리케이션 유형" 드롭다운 메뉴에서 "웹 애플리케이션"을 선택하세요. Laravel Socialite를 Google과 통합하려면 "Authorized JavaScript Source" 및 "Redirect URI" 필드를 채워야 합니다.
"승인된 JavaScript 소스" 필드에 애플리케이션의 호스트 이름을 입력하면 "http://localhost" URL을 로컬에서 사용할 수 있습니다. '리디렉션 URI' 필드에 Google에서 로그인한 후 애플리케이션으로 다시 리디렉션할 콜백 URL을 입력합니다. 이 예에서는 "http://localhost:8000/auth/google/callback" URL을 사용합니다.
생성 후 클라이언트 ID와 클라이언트 비밀번호가 제공됩니다. 이 자격 증명을 저장하면 나중에 Laravel에서 사용할 것입니다.
Laravel Socialite 설치 및 구성
Laravel Socialite는 명령줄 설치를 통해 사용할 수 있는 Composer 패키지입니다. 설치하려면 다음 명령을 사용합니다:
composer require laravel/socialite
설치가 완료된 후 Laravel 구성 파일에 Socialite 서비스 공급자를 추가합니다:
'providers' => [ // ... LaravelSocialiteSocialiteServiceProvider::class, ],
또한 Laravel 구성 파일에 다음 구성 정보를 추가해야 합니다:
'client_id' => env('GOOGLE_CLIENT_ID'), 'client_secret' => env('GOOGLE_CLIENT_SECRET'), 'redirect' => env('GOOGLE_REDIRECT'),
여기서는 필수 구성 정보가 들어 있는 .env
파일을 사용했습니다. .env
文件保存需要的配置信息:
GOOGLE_CLIENT_ID=your-client-id GOOGLE_CLIENT_SECRET=your-client-secret GOOGLE_REDIRECT=http://localhost:8000/auth/google/callback
Laravel Socialite集成
在这里,我们需要创建一个路由处理程序,它将处理与Google的OAuth流程。
Route::get('/auth/google', function () { return Socialite::driver('google')->redirect(); }); Route::get('/auth/google/callback', function () { $user = Socialite::driver('google')->user(); dd($user); });
第一个路由处理程序将重定向用户到Google登录流程。
在成功后,用户将被重定向到第二个路由处理程序中。 此时,我们可以使用user()
$user = Socialite::driver('google')->user(); dd($user);
Route::get('/auth/google/callback', function () { $user = Socialite::driver('google')->user(); // save application user $authUser = User::where('email', $user->email)->first(); if ($authUser) { Auth::login($authUser, true); return redirect('/home'); } // create application user $newUser = new User; $newUser->name = $user->name; $newUser->email = $user->email; $newUser->password = bcrypt(str_random(16)); $newUser->save(); Auth::login($newUser, true); return redirect('/home'); });
user()
메소드를 사용하여 로그인한 사용자의 정보를 얻을 수 있습니다. 반환된 사용자 코드를 입력하고 얻은 사용자 정보를 인쇄하세요. rrreee
사용자 이름, 이메일 주소, 아바타, 토큰 등과 같은 사용자에 대한 기타 데이터가 표시됩니다. 이 정보를 바탕으로 타사 로그인을 구현할 수 있습니다. 여기에서는 위에서 얻은 사용자 정보를 사용하여 애플리케이션 사용자를 생성하고 인증합니다.rrreee
여기서는 Google에서 반환한 이메일 주소를 사용하여 기존 앱 사용자를 찾는 것부터 시작합니다. 발견되면 Laravel의 인증 API를 사용하여 로그인하세요. 찾을 수 없으면 새 사용자를 생성하고 Laravel의 인증 API를 사용하여 로그인하세요. 결론🎜🎜이 글에서는 Laravel Socialite와 Google을 이용하여 써드파티 로그인을 구현하는 방법을 소개합니다. 🎜🎜Google Dev Platform 설정을 통해 필요한 OAuth 자격 증명을 생성했습니다. 그런 다음 Laravel Socialite를 사용하여 OAuth 프로세스에서 지루한 단계와 코드를 제거했습니다. 마지막으로 사용자의 기존 이메일 주소를 사용하여 새 사용자를 인증하고 생성합니다. 🎜🎜이 글이 Laravel Socialite와 Google을 사용하여 제3자 로그인을 구현하는 방법에 대한 지침을 제공하고 OAuth 프로세스에 대한 개요를 다루기를 바랍니다. 🎜위 내용은 Laravel 개발: Laravel Socialite와 Google을 사용하여 타사 로그인을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!