微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

AWS PHP SDK-如何为联合用户生成用于登录的终端节点?

如何解决AWS PHP SDK-如何为联合用户生成用于登录的终端节点?

有人可以帮助我使用 AWS STS getFederationToken API为联盟用户生成登录端点吗?

以下是我的代码-

<?PHP
require 'aws-autoloader.PHP';
use Aws\Sts\StsClient; 
use Aws\Sts\Exception\StsException;

$credentials = new Aws\Credentials\Credentials('MYKEY','MYSECRET');

$client = new StsClient([
    'region' => 'ap-south-1','version' => '2011-06-15','credentials' => $credentials
]);


try {
    
    $result = $client->getFederationToken(array(
    // Name is required
    'Name' => 'sv','Policy' => '{
  "Version": "2012-10-17","Statement": [
    {
      "Action": [
    "sns:*"
      ],"Effect": "Allow","Resource": "*"
    }
  ]
}','DurationSeconds' => 28000,));

    //echo '<pre>'; print_r($result);die;
   

$json_data = json_encode(['sessionId' => '$result["Credentials"]["AccessKeyId"]','sessionKey' => '$result["Credentials"]["SecretAccessKey"]','sessionToken' => '$result["Credentials"]["SessionToken"]'
]);

$issuer = urlencode("https://signin.aws.amazon.com/");

$destination = urlencode("https://console.aws.amazon.com/sns");

$sign_in_url = "https://signin.aws.amazon.com/federation?Action=getSigninToken&SessionType=json&Session=".urlencode($json_data);

$ch = curl_init();

// Will return the response,if false it print the response
curl_setopt($ch,CURLOPT_RETURNTRANSFER,true);
// Set the url
curl_setopt($ch,CURLOPT_URL,$sign_in_url);
// Execute
$result=curl_exec($ch);

// Closing
curl_close($ch);

// Print the return data
$res = json_decode($result,true);

$sign_in_token = $res['SigninToken'];

$login_url = "https://signin.aws.amazon.com/federation?Action=login&Issuer=".$issuer."&Destination=".$destination."&SigninToken=".$sign_in_token;

echo $login_url;

} catch (StsException $e) {
    // output error message if fails
    print_r($e->getMessage());
}

正在产生以下链接-

https://signin.aws.amazon.com/federation?Action=login&Issuer=https%3A%2F%2F637313748738.signin.aws.amazon.com%2F&Destination=https%3A%2F%2Fconsole.aws.amazon.com%2Fsns&SigninToken=CQTyMmOL8tnbJPAShBeAg8VhrWUz2Np9P00bkH096kjZkIhaPWZX_iiiUuEkX6dw11eZTDKpxEO2ev5PtdojVjOLrAg_ugJe9ITledsTzaJO51ccPlYb0lSdntE3Jo8YESqynHPDyCiuueoc2vec-YZ7hOfllHrqhCnNsmPkKPy_51oWSLHVH6_GQp_n2QLwu-H6T5EfcHV9nY7i5slkzd64M6z7XrLkqvB_smH6cUhXizq37x0yIzcdD0OBTqLAyyRBoKoZ-GRmtTXy6V7A2KS-C0jARgfA9hiaclyFQ9lgZM_LwV8mBTFk9WdUB-l0-QMvlmSJ5Y7LFWKvSC1BgqvLpCbj9cFlri2bQ3yT1pCarOInlUkqayjXYkrzQh1wpmwxexPXJey9IB7jCDi53c1wNwGYR2u2CMXSyAGeBt2XGpL-5_oYN3djWbEYfupFuS4Ert069XEIk-HKtIulnckJwjiaMDijR1Fj1bXkMiMYobZxSWUX7KsaBQ4RzApwr5wzMleWSF_SfC_ppfHifRHXzHXi

但是当我尝试单击此链接时,它说- 您的登录链接中的凭据无效。请与您的管理员联系。

Please see attached image

上面的代码有什么问题?

谢谢!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。