>PHP 프레임워크 >Laravel >Laravel 개발: Laravel Socialite를 사용하여 소셜 로그인을 구현하는 방법은 무엇입니까?

Laravel 개발: Laravel Socialite를 사용하여 소셜 로그인을 구현하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-06-13 22:09:171269검색

오늘날 점점 발전하는 소셜 네트워크 시대에 소셜 로그인은 점점 더 많은 웹사이트의 표준 기능이 되었습니다. 이는 사용자가 빠르게 로그인할 수 있게 할 뿐만 아니라 웹사이트의 사용자 트래픽과 사회적 상호 작용을 늘리는 데도 도움이 됩니다. 소셜 로그인을 직접 구현하는 것은 어렵지 않지만 기성 소셜 로그인 구성 요소를 사용하면 시간과 노력을 절약할 수 있습니다. PHP 개발에서 Laravel Socialite는 사용하기 쉬운 소셜 로그인 컴포넌트입니다. 이를 사용하여 소셜 로그인을 구현하는 방법을 살펴보겠습니다.

1. Laravel Socialite 설치

먼저 Laravel 애플리케이션에 Socialite 패키지를 설치해야 합니다.

composer require laravel/socialitecomposer require laravel/socialite

安装完成之后,在 config/app.php 文件中添加 Socialite 服务提供器:

'providers' => [
    // Other service providers...

    LaravelSocialiteSocialiteServiceProvider::class,
]

然后在 config/app.php 文件中添加 Socialite 门面别名:

'aliases' => [
    // Other aliases...

    'Socialite' => LaravelSocialiteFacadesSocialite::class,
]

这样我们就成功安装了 Socialite 组件。

二、创建社交登录应用

Socialite 可以支持许多不同的社交登录应用,我们需要为每个应用创建一个应用程序。下面以 GitHub 为例演示在 GitHub 上创建一个新的 OAuth 应用。

  1. 首先,登录你的 GitHub 账户,在头像下拉菜单中选择 Settings->Developer settings->OAuth Apps 进入 OAuth Apps 页面。

4c9445fc537046e0a1fee66c02b2052c

  1. 点击 New OAuth App 按钮,填入以下信息:
  • Application name:应用程序名称;
  • Homepage URL:应用程序主页的 URL;
  • Authorization callback URL:社交登录认证成功后的回调 URL。

填写完成后点击 Register application 按钮。

2be3281443d79c148a2ccf1c82e49284

  1. 生成应用程序的 Client ID 和 Client Secret。

f80b2d685844d774c0300217a7821f1e

三、实现社交登录

  1. 首先,在应用程序的登录页面中添加社交登录按钮,并将其链接到 Socialite 的 GitHub 认证服务中:
<a href="{{ url('/auth/github') }}">使用GitHub登录</a>
  1. 在 Laravel 中创建 GitHub 登录路由。打开 routes/web.php 文件并添加以下路由定义:
Route::get('auth/github', 'AuthLoginController@redirectToProvider');
Route::get('auth/github/callback', 'AuthLoginController@handleProviderCallback');

这里要求我们通过 redirectToProvider 将用户重定向到 GitHub 认证服务,并在那里完成登录认证。当认证成功后,GitHub 认证服务将重定向到指定的回调 URL auth/github/callback,并通过该 URL 在 Session 中传递认证成功的用户信息。

  1. 构建 redirectToProvider 函数。打开 app/Http/Controllers/Auth/LoginController.php 文件,并添加以下实现方式:
namespace AppHttpControllersAuth;

use IlluminateHttpRequest;
use AppHttpControllersController;
use Socialite;

class LoginController extends Controller
{
    // ...
    public function redirectToProvider()
    {
        return Socialite::driver('github')->redirect();
    }
    // ...
}

我们调用 Socialite 中的 driver() 方法来获取 GitHub 认证驱动程序的实例,并使用 redirect() 方法将用户重定向到登录认证服务。

  1. 接下来,我们将在 handleProviderCallback 方法中处理认证成功后的回调。打开 app/Http/Controllers/Auth/LoginController.php 文件,并添加以下方法:
// ...
public function handleProviderCallback()
{
    try {
        $user = Socialite::driver('github')->user();
    } catch (Exception $e) {
        return redirect('/login');
    }

    // 验证用户信息并完成登录,代码省略
    // ...
}
// ...

我们使用 Socialite 中的 user() 方法获取 GitHub 认证服务返回的用户信息。如果在认证过程中有任何错误,我们将重定向用户到应用程序的登录页面。如果认证成功,则可以使用 $user

설치가 완료된 후 config/ app.php 파일에 Socialite 서비스 공급자를 추가합니다:

rrreee

그런 다음 config/app.php 파일에 Socialite 파사드 별칭을 추가합니다:

rrreee

In 이런 식으로 Socialite 구성 요소를 성공적으로 설치했습니다. 🎜🎜2. 소셜 로그인 애플리케이션 만들기 🎜🎜Socialite는 다양한 소셜 로그인 애플리케이션을 지원할 수 있으며 각 애플리케이션에 대한 애플리케이션을 만들어야 합니다. 다음은 GitHub에서 새 OAuth 애플리케이션을 생성하는 방법을 보여주는 예제로 GitHub를 사용합니다. 🎜
  1. 먼저 GitHub 계정에 로그인하고 아바타 드롭다운 메뉴에서 설정->개발자 설정->OAuth 앱을 선택하여 OAuth 앱 페이지로 들어갑니다.
🎜030de7539521f967a0930f7e8fe6c212🎜
  1. 새 OAuth 앱 버튼을 클릭하고 다음 정보를 입력하세요.
  • 애플리케이션 이름: 애플리케이션 이름
  • 홈페이지 URL: 애플리케이션 홈페이지 URL ;
  • 인증 콜백 URL: 소셜 로그인 인증 성공 후의 콜백 URL입니다.
🎜입력을 완료한 후 신청서 등록 버튼을 클릭하세요. 🎜🎜7e7748ab6b0dec43e80d953a3c73e418🎜
  1. 애플리케이션 클라이언트 생성 ID 및 클라이언트 비밀번호.
🎜5c569b628954eefe2397bf53696f788b🎜🎜3. 소셜 로그인 구현🎜
  1. 먼저 애플리케이션의 로그인 페이지에 소셜 로그인 버튼을 추가하고 이를 Socialite의 GitHub 인증 서비스에 연결합니다:
rrreee
    GitHub 로그인 만들기 Laravel의 경로. routes/web.php 파일을 열고 다음 경로 정의를 추가하세요:
rrreee🎜여기서 redirectToProvider를 통해 사용자를 GitHub 인증 서비스로 리디렉션하라는 메시지가 표시됩니다. 를 클릭하고 그곳에서 로그인 인증을 완료하세요. 인증이 성공하면 GitHub 인증 서비스는 지정된 콜백 URL auth/github/callback으로 리디렉션되고, 이 URL을 통해 세션에서 성공적으로 인증된 사용자 정보를 전달합니다. 🎜
  1. redirectToProvider 함수를 빌드하세요. app/Http/Controllers/Auth/LoginController.php 파일을 열고 다음 구현을 추가합니다:
rrreee🎜코드에서 Socialite를 호출합니다> Driver() 메서드를 사용하여 GitHub 인증 드라이버의 인스턴스를 얻고, redirect() 메서드를 사용하여 사용자를 로그인 인증 서비스로 리디렉션합니다. 🎜
  1. 다음으로 handleProviderCallback 메서드에서 인증 성공 후 콜백을 처리하겠습니다. app/Http/Controllers/Auth/LoginController.php 파일을 열고 다음 메소드를 추가하세요:
rrreee🎜우리는 Socialite를 사용합니다 > >user() 메소드는 GitHub 인증 서비스에서 반환된 사용자 정보를 가져옵니다. 인증 프로세스 중에 오류가 있는 경우 사용자를 애플리케이션의 로그인 페이지로 리디렉션합니다. 인증이 성공하면 $user 객체의 정보를 사용하여 사용자를 인증하고 로그인 작업을 완료할 수 있습니다. 🎜🎜4. 요약🎜🎜이제 Laravel Socialite를 사용하여 GitHub 소셜 로그인을 구현하는 과정이 완료되었습니다. 간단한 구성과 필요한 코드를 통해 다양한 소셜 로그인 방법을 쉽게 구현할 수 있으며 실제 프로젝트에서 사용하도록 권장되는 작지만 유용한 기능을 애플리케이션에 추가할 수 있습니다. 🎜

위 내용은 Laravel 개발: Laravel Socialite를 사용하여 소셜 로그인을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.