为了能够使用任何API请求,您需要首先正确设置您的凭据。如果在EC2实例之外进行服务器端设置,您需要提供以下信息:AWS访问密钥、AWS秘密访问密钥、应用程序客户端ID、应用程序客户端密码和用户池ID,如下所示:
$args = [
'credentials' => [
'key' => 'AAAAAAAAAA',
'secret' => 'abacaaswfas',
],
'region' => 'eu-central-1',
'version' => 'latest',
'app_client_id' => '3asd123adfs1231sdfs',
'app_client_secret' => '1sdf123sdfs123sdfsfsdf132fd3213',
'user_pool_id' => 'eu-central-1_aaaW2Df3',
]
否则,在正确的ID放置之前,您将看到各种可能的错误。
要获取AWS ACCESS KEY和AWS SECRET ACCESS KEY,请转到AWS控制台,单击您的名称,然后转到帐户,再次单击您的名称,进入“我的安全凭据”,然后我想您会找到出路。
要获取应用程序客户端ID、应用程序客户端密钥,您需要首先创建用户池,然后转到应用程序客户端并创建一个(您可以在“常规设置”下找到池ID)。
一个简单的登录查询。
$client = new CognitoIdentityProviderClient($args);
$client->adminInitiateAuth([
'AuthFlow' => 'ADMIN_NO_SRP_AUTH',
'AuthParameters' => [
'USERNAME' => YOUR_USERNAME_HERE,
'PASSWORD' => YOUR_PASS_HERE,
'SECRET_HASH' => , base64_encode(hash_hmac('sha256', YOUR_USERNAME_HERE . APP_CLIENT_ID, APP_CLIENT_SECRET, true))
],
'ClientId' => APP_CLIENT_ID,
'UserPoolId' => USER_POOL_ID,
]);
如果您成功运行此操作,您应该能够使用文档
这里列出的任何操作。
注意:此操作适用于API版本2016-04-18和PHP 7.1,请确保您使用的是相同的版本或API没有重大更改,然后再假定此操作将适用于您。
注意2:我使用的ID完全是随机的..但它们应该具有相同的格式。