>백엔드 개발 >PHP 튜토리얼 >AWS Cognito를 사용한 PHP 보안 인증

AWS Cognito를 사용한 PHP 보안 인증

PHPz
PHPz원래의
2023-07-26 14:54:26915검색

AWS Cognito를 사용한 PHP 보안 인증

AWS Cognito는 개발자가 애플리케이션에 대한 사용자 관리 및 인증 기능을 쉽게 구현할 수 있도록 지원하는 사용자 인증 및 권한 부여 서비스입니다. 이 기사에서는 PHP와 함께 AWS Cognito를 사용하여 보안 확인 기능을 구현하는 방법을 알아봅니다. 코드 예제를 작성하여 구체적인 구현 단계를 보여드리겠습니다.

전제 조건
이 문서에 설명된 기능을 성공적으로 구현하려면 다음 전제 조건을 충족해야 합니다.

  1. AWS 계정 및 AWS CLI(명령줄 인터페이스)에 대한 액세스 권한이 있어야 합니다.
  2. AWS Cognito 서비스가 완료되었습니다. 구성 및 활성화되었습니다.

1단계: 사용자 풀 생성
먼저, 사용자 자격 증명 및 기타 관련 정보를 저장하고 관리하기 위해 AWS Cognito에서 사용자 풀을 생성해야 합니다. AWS CLI 또는 AWS Management 콘솔을 사용하여 사용자 풀을 생성할 수 있습니다. 다음은 AWS CLI를 사용하여 사용자 풀을 생성하는 명령의 예입니다.

aws cognito-idp create-user-pool --pool-name MyUserPool --auto-verified-attributes email --policies PasswordPolicies=RequiredLength=8,RequireUppercase=true,RequireLowercase=true,RequireNumbers=true,RequireSymbols=true --schema Name=email,AttributeDataType=Email:STRING,Required=true,Name=phone_number,AttributeDataType=Number:STRING,Required=false

위 명령은 이메일 확인이 활성화되고 암호가 지정된 규칙과 일치해야 하는 MyUserPool이라는 사용자 풀을 생성합니다.

2단계: 사용자 풀 클라이언트 설정
다음으로, 애플리케이션에서 사용자 인증을 위해 이 클라이언트를 사용할 수 있도록 애플리케이션용 사용자 풀 클라이언트를 생성해야 합니다. AWS CLI 또는 AWS Management 콘솔을 사용하여 사용자 풀 클라이언트를 생성할 수 있습니다. 다음은 AWS CLI를 사용하여 사용자 풀 클라이언트를 생성하는 명령의 예입니다.

aws cognito-idp create-user-pool-client --user-pool-id YOUR_USER_POOL_ID --client-name MyUserPoolClient --no-generate-secret --explicit-auth-flows ALLOW_REFRESH_TOKEN_AUTH --refresh-token-validity 30

위 명령은 MyUserPoolClient라는 사용자 풀 클라이언트를 생성하고 30일 동안 유효한 새로 고침 토큰을 사용한 인증을 허용합니다.

3단계: 인증 구현을 위한 PHP 코드
사용자 풀과 사용자 풀 클라이언트를 생성했으므로 다음으로 인증 기능을 구현하는 PHP 코드를 작성하겠습니다.

먼저 PHP용 AWS SDK를 도입해야 합니다. Composer를 통해 설치하거나 PHP용 AWS SDK의 소스 코드를 직접 다운로드하여 가져올 수 있습니다.

require 'vendor/autoload.php'; // 引入 AWS SDK for PHP 的自动加载文件
use AwsCognitoIdentityProviderCognitoIdentityProviderClient;

그런 다음 AWS Cognito 액세스 자격 증명을 구성해야 합니다. AWS Management Console에서 사용자 풀 ID, 사용자 풀 클라이언트 ID, AWS 리전 정보를 찾아 아래 코드에서 해당 값을 바꿀 수 있습니다.

$poolId = 'YOUR_USER_POOL_ID';
$clientId = 'YOUR_USER_POOL_CLIENT_ID';
$region = 'YOUR_AWS_REGION';

다음으로 CognitoIdentityProviderClient를 인스턴스화하고 적절한 구성을 설정해야 합니다.

$client = new CognitoIdentityProviderClient([
    'version' => 'latest',
    'region' => $region
]);
$client->setCredentials([
    'key' => 'YOUR_AWS_ACCESS_KEY_ID',
    'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY'
]);

이제 인증할 준비가 되었습니다. 다음 코드 조각은 AWS Cognito로 인증하는 방법을 보여줍니다.

$result = $client->adminInitiateAuth([
    'UserPoolId' => $poolId,
    'ClientId' => $clientId,
    'AuthFlow' => 'ADMIN_NO_SRP_AUTH',
    'AuthParameters' => [
        'USERNAME' => 'testuser@example.com',
        'PASSWORD' => 'P@ssw0rd'
    ]
]);
var_dump($result);

위 코드에서는 adminInitiateAuth 方法进行身份验证。您需要替换 'USERNAME''PASSWORD' 的值为您的实际用户名和密码。成功验证后,$result 변수를 사용하여 인증 결과를 담았습니다.

결론
이번 글을 통해 AWS Cognito를 활용하여 PHP 보안 검증 기능을 구현하는 방법을 알아보았습니다. 사용자 풀과 사용자 풀 클라이언트를 생성한 다음 인증을 위해 PHP 코드를 사용하여 이를 수행합니다. AWS Cognito는 사용자 자격 증명을 관리하고 인증을 구현하는 간단하면서도 강력한 방법을 제공하여 애플리케이션을 더욱 안전하고 안정적으로 만듭니다.

위 내용은 AWS Cognito를 사용한 PHP 보안 인증의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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