> 백엔드 개발 > PHP 튜토리얼 > PHP의 OAuth: 타사 로그인 기능 통합

PHP의 OAuth: 타사 로그인 기능 통합

WBOY
풀어 주다: 2023-07-29 07:26:02
원래의
783명이 탐색했습니다.

PHP의 OAuth: 통합된 제3자 로그인 기능

소셜 미디어의 급속한 발전과 함께 점점 더 많은 웹사이트와 애플리케이션이 사용자의 Facebook, Google 또는 WeChat 계정을 사용하여 로그인하는 등 제3자 로그인 기능을 제공하고 있습니다. 이 방법은 사용자에게 편리할 뿐만 아니라 사용자 등록 및 로그인 전환율도 향상시킵니다. PHP에서는 OAuth 프로토콜을 통해 이 기능을 구현할 수 있습니다. 이 기사에서는 PHP에서 OAuth를 활용하여 타사 로그인 기능을 통합하는 방법을 살펴보겠습니다.

OAuth는 사용자가 비밀번호를 제공하지 않고도 타사 애플리케이션이 자신의 데이터에 액세스할 수 있도록 승인할 수 있는 인증 프로토콜입니다. 제3자 로그인에서 OAuth는 제3자 플랫폼의 API를 사용하여 사용자의 기본 정보 및 권한을 얻을 수 있는 안전한 방법을 제공합니다.

먼저 OAuth 인증 자격 증명을 얻으려면 개발자 계정을 등록해야 합니다. 이 프로세스에는 일반적으로 애플리케이션을 생성하고 클라이언트 ID 및 클라이언트 암호와 같은 자격 증명을 얻는 작업이 포함됩니다. Facebook을 예로 들면, 애플리케이션을 생성하려면 Facebook 개발자 플랫폼으로 이동해야 합니다.

자격 증명이 있으면 PHP 코드를 작성하여 타사 로그인 기능을 구현할 수 있습니다. 우리는 전체 프로세스를 단순화하기 위해 League/OAuth2-Client와 같은 널리 사용되는 PHP 라이브러리를 사용할 것입니다.

먼저 Composer를 통해 설치할 수 있는 이 라이브러리를 설치해야 합니다. 터미널에서 다음 명령을 실행하세요:

composer require league/oauth2-client
로그인 후 복사

다음으로 인증 콜백 로직을 처리할 oauth_callback.php라는 파일을 작성할 수 있습니다. 다음은 기본 예입니다.

<?php
require 'vendor/autoload.php';
 
$provider = new LeagueOAuth2ClientProviderGenericProvider([
    'clientId'                => 'YOUR_CLIENT_ID',
    'clientSecret'            => 'YOUR_CLIENT_SECRET',
    'redirectUri'             => 'http://your-domain.com/oauth_callback.php',
    'urlAuthorize'            => 'https://oauth.provider.com/authorize',
    'urlAccessToken'          => 'https://oauth.provider.com/access_token',
    'urlResourceOwnerDetails' => 'https://oauth.provider.com/resource_owner'
]);
 
if (!isset($_GET['code'])) {
    $authorizationUrl = $provider->getAuthorizationUrl();
    $_SESSION['oauth2state'] = $provider->getState();
    header('Location: ' . $authorizationUrl);
    exit;
} elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) {
    unset($_SESSION['oauth2state']);
    exit('Invalid state');
} else {
    $accessToken = $provider->getAccessToken('authorization_code', [
        'code' => $_GET['code']
    ]);
 
    $resourceOwner = $provider->getResourceOwner($accessToken);
    $user = $resourceOwner->toArray();
 
    // 获取第三方登录用户的基本信息
    $email = $user['email'];
    $name = $user['name'];
 
    // 进行自己的业务逻辑
}
로그인 후 복사

이 예에서는 GenericProvider를 OAuth 공급자로 사용합니다. YOUR_CLIENT_ID 및 YOUR_CLIENT_SECRET을 개발자 플랫폼에서 얻은 자격 증명으로 바꿔야 합니다. RedirectUri는 사용자 인증 후의 콜백 URL로, 애플리케이션에서 설정한 콜백 URL과 일치해야 합니다.

프런트 엔드 페이지에서 다음 주소를 가리키는 버튼이나 링크를 추가할 수 있습니다.

<a href="oauth_callback.php">使用第三方登录</a>
로그인 후 복사

사용자가 이 링크를 클릭하면 타사 플랫폼의 인증 페이지로 리디렉션되어 다음을 요청합니다. 우리 애플리케이션이 그들의 계정 정보에 접근할 수 있도록 승인하세요. 성공적으로 승인되면 코드 매개변수와 함께 oauth_callback.php 페이지로 다시 리디렉션됩니다.

getAccessToken 메서드를 호출하면 액세스 토큰을 얻을 수 있습니다. 그런 다음 getResourceOwner 메소드를 사용하여 이메일, 이름과 같은 사용자의 기본 정보를 얻을 수 있습니다.

마지막으로, 사용자 계정 생성, 기존 계정 로그인 등 자체 비즈니스 로직에 따라 이 정보를 처리할 수 있습니다.

요약하자면, PHP에서 OAuth 프로토콜을 사용하면 타사 로그인 기능을 쉽게 통합할 수 있습니다. 이 기사가 귀하의 애플리케이션에 더 많은 로그인 옵션을 추가하는 데 도움이 되기를 바랍니다.

위 내용은 PHP의 OAuth: 타사 로그인 기능 통합의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿