

本文属于机器翻译版本。若本译文内容与英语原文存在差异，则一律以英文原文为准。

# 基于身份的策略
<a name="auth-and-access_iam-policies"></a>

将权限策略附加到 [IAM 身份、用户、用户组和角色](https://docs.amazonaws.cn/IAM/latest/UserGuide/id.html)。在基于身份的策略中，您指定该身份可以访问哪些密钥以及该身份可以对密钥执行哪些操作。有关更多信息，请参阅[添加和删除 IAM 身份权限](https://docs.amazonaws.cn/IAM/latest/UserGuide/access_policies_manage-attach-detach.html)。

您可以向代表其他服务中的应用程序或用户的角色授予权限。例如，在 Amazon EC2 实例上运行的应用程序可能需要访问数据库。您可以创建附加到 EC2 实例配置文件的 IAM 角色，然后使用权限策略授予该角色对包含数据库凭证的密钥的访问权限。有关更多信息，请参阅[使用 IAM 角色为 Amazon EC2 实例上运行的应用程序授予权限](https://docs.amazonaws.cn/IAM/latest/UserGuide/id_roles_use_switch-role-ec2.html)。您可以附加角色的其他服务包括 [Amazon Redshift](https://docs.amazonaws.cn/redshift/latest/dg/c-getting-started-using-spectrum.html)、[Amazon Lambda](https://docs.amazonaws.cn/lambda/latest/dg/lambda-permissions.html) 和 [Amazon ECS](https://docs.amazonaws.cn/AmazonECS/latest/developerguide/task_execution_IAM_role.html)。

您还可以通过除 IAM 以外的其他身份系统验证的用户授予权限。例如，您可以将 IAM 角色与使用 Amazon Cognito 登录的移动应用程序用户关联。角色向应用程序授予具有角色权限策略中权限的临时凭据。然后，您可以使用权限策略授予角色对密钥的访问权限。有关更多信息，请参阅[身份提供者和联合身份验证](https://docs.amazonaws.cn/IAM/latest/UserGuide/id_roles_providers.html)。

您必须使用基于身份的策略来：
+ 授予对多个密钥的身份访问权限。
+ 控制哪些人可以创建新密钥，哪些人可以访问尚未创建的密钥。
+ 授予 IAM 组对密钥的访问权限。

**Topics**
+ [示例：检索单个秘密值的权限](#auth-and-access_examples_identity_read)
+ [示例：读取和描述个人密钥的权限](#auth-and-access_examples-read-and-describe)
+ [示例：批量检索一组密钥值的权限](#auth-and-access_examples_batch)
+ [示例：通配符](#auth-and-access_examples_wildcard)
+ [示例：创建密钥的权限](#auth-and-access_examples_create)
+ [示例：拒绝使用特定 Amazon KMS 密钥来加密机密](#auth-and-access_examples_kmskey)

## 示例：检索单个秘密值的权限
<a name="auth-and-access_examples_identity_read"></a>

要授予检索密钥值的权限，您可以将策略附加到密钥或身份上。要帮助确定使用的策略类型，请参阅[基于身份的策略和基于资源的策略](https://docs.amazonaws.cn/IAM/latest/UserGuide/access_policies_identity-vs-resource.html)。有关如何附加策略的信息，请参阅 [基于资源的策略](auth-and-access_resource-policies.md) 和 [基于身份的策略](#auth-and-access_iam-policies)。

当您希望授予对 IAM 组的访问权限时，此示例非常有用。要授予在批处理 API 调用中检索一组秘密的权限，请参阅 [示例：批量检索一组密钥值的权限](#auth-and-access_examples_batch)。

**Example 读取使用客户自主管理型密钥加密的密钥**  
如果使用客户管理的密钥对密钥进行加密，则可以通过将以下策略附加到身份来授予读取该密钥的访问权限。    
****  

```
{
"Version":"2012-10-17",		 	 	 
"Statement": [
{
  "Effect": "Allow",
  "Action": "secretsmanager:GetSecretValue",
  "Resource": "arn:aws:secretsmanager:us-east-1:123456789012:secret:secretName-AbCdEf"
},
{
  "Effect": "Allow",
  "Action": "kms:Decrypt",
  "Resource": "arn:aws:kms:us-east-1:123456789012:key/key-id"
}
]
}
```

## 示例：读取和描述个人密钥的权限
<a name="auth-and-access_examples-read-and-describe"></a>

**Example 读取和描述一个密钥**  
通过将以下策略附加到身份，您可以授予密钥的访问权限。    
****  

```
{
"Version":"2012-10-17",		 	 	 
"Statement": [
  {
    "Effect": "Allow",
    "Action": [
      "secretsmanager:GetSecretValue",
      "secretsmanager:DescribeSecret"
      ],
      "Resource": "arn:aws:secretsmanager:us-east-1:123456789012:secret:secretName-AbCdEf"
    }
]
}
```

## 示例：批量检索一组密钥值的权限
<a name="auth-and-access_examples_batch"></a>

**Example 批量读取一组密钥**  
您可以通过将以下策略附加到身份来授予在批处理 API 调用中检索一组秘密的访问权限。该策略限制了调用方，因此即使批量调用包含其他密钥 *SecretARN1**SecretARN2*，他们也只能检索*SecretARN3*、和指定的密钥。如果调用方还在批处理 API 调用中请求其他秘密，则 Secrets Manager 将不会返回它们。有关更多信息，请参阅[`BatchGetSecretValue`。](https://docs.amazonaws.cn/secretsmanager/latest/apireference/API_BatchGetSecretValue.html) 。    
****  

```
{
"Version":"2012-10-17",		 	 	 
"Statement": [
{
  "Effect": "Allow",
  "Action": [
    "secretsmanager:BatchGetSecretValue",
    "secretsmanager:ListSecrets"
  ],
  "Resource": "*"
},
{
  "Effect": "Allow",
  "Action": [
    "secretsmanager:GetSecretValue"
  ],
  "Resource": [
    "arn:aws:secretsmanager:us-east-1:123456789012:secret:secretName1-AbCdEf",
    "arn:aws:secretsmanager:us-east-1:123456789012:secret:secretName2-AbCdEf",
    "arn:aws:secretsmanager:us-east-1:123456789012:secret:secretName3-AbCdEf"
    ]
}
]
}
```

## 示例：通配符
<a name="auth-and-access_examples_wildcard"></a>

您可以使用通配符在策略元素中包含一组值。

**Example 访问路径中的所有密钥**  
以下策略授予检索名称以 “*TestEnv/*” 开头的所有密钥的权限。    
****  

```
{
    "Version":"2012-10-17",		 	 	 
    "Statement": {
        "Effect": "Allow",
        "Action": "secretsmanager:GetSecretValue",
        "Resource": "arn:aws:secretsmanager:us-east-1:123456789012:secret:TestEnv/*"
    }
}
```

**Example 访问所有密钥的元数据**  
以下策略授予 `DescribeSecret` 和权限开头为 `List`：`ListSecrets` 和 `ListSecretVersionIds`。    
****  

```
{
"Version":"2012-10-17",		 	 	 
"Statement": {
"Effect": "Allow",
"Action": [
  "secretsmanager:DescribeSecret",
  "secretsmanager:List*"
],
"Resource": "*"
}
}
```

**Example 匹配密钥名称**  
以下策略按名称授予密钥的所有 Secrets Manager 权限。要使用该策略，请参阅 [基于身份的策略](#auth-and-access_iam-policies)。  
要匹配密钥名称，可以通过将区域、账户 ID、机密名称和通配符 (`?`) 放在一起来匹配单个随机字符，从而为密钥创建 ARN。Secrets Manager 会将六个随机字符附加到密钥名称作为 ARN 的一部分，因此您可以使用此通配符来匹配这些字符。如果使用 `"another_secret_name-*"` 语法，Secrets Manager 不仅匹配具有 6 个随机字符的预期密钥，而且还匹配 `"another_secret_name-<anything-here>a1b2c3"`。  
因为除了 6 个随机字符外，您可以预测密钥的所有 ARN 部分，所以使用通配符 `'??????'` 语法，您能够安全地将权限授予给尚不存在的密钥。但要注意，如果删除密钥并以相同名称重新创建，即使 6 个字符发生变化，用户也会自动获得新密钥的权限。    
****  

```
{
    "Version":"2012-10-17",		 	 	 
    "Statement": [
        {
            "Effect": "Allow",
            "Action": "secretsmanager:*",
            "Resource": [
                "arn:aws:secretsmanager:us-east-1:123456789012:secret:a_specific_secret_name-a1b2c3",
                "arn:aws:secretsmanager:us-east-1:123456789012:secret:another_secret_name-??????"
            ]
        }
    ]
}
```

## 示例：创建密钥的权限
<a name="auth-and-access_examples_create"></a>

要为用户授予权限创建密钥，我们建议您将权限策略附加到用户所属的 IAM 组。请参阅 [IAM 用户组](https://docs.amazonaws.cn/IAM/latest/UserGuide/id_groups.html)。

**Example 创建密钥**  
以下策略授予创建密钥和查看密钥列表的权限。要使用该策略，请参阅 [基于身份的策略](#auth-and-access_iam-policies)。    
****  

```
{
"Version":"2012-10-17",		 	 	 
"Statement": [
{
  "Effect": "Allow",
  "Action": [
    "secretsmanager:CreateSecret",
    "secretsmanager:ListSecrets"
  ],
  "Resource": "*"
}
]
}
```

## 示例：拒绝使用特定 Amazon KMS 密钥来加密机密
<a name="auth-and-access_examples_kmskey"></a>

**重要**  
要拒绝客户自主管理型密钥，我们建议您使用密钥策略或密钥授予来限制访问权限。有关更多信息，请参阅《*Amazon Key Management Service 开发人员指南*》中的 [Authentication and access control for Amazon KMS](https://docs.amazonaws.cn/kms/latest/developerguide/control-access.html)。

**Example 拒绝 Amazon 托管密钥 `aws/secretsmanager`**  
以下策略拒绝使用来创建或更新密钥。 Amazon 托管式密钥 `aws/secretsmanager`此策略要求使用客户自主管理型密钥来加密密钥。该策略包含两条语句：  

1. 第一条语句拒绝使用创建或更新密钥的请求 Amazon 托管式密钥 `aws/secretsmanager`。`Sid: "RequireCustomerManagedKeysOnSecrets"`

1. 第二条语句拒绝创建不包含 KMS 密钥的密钥的请求，因为 Secrets Manager 会默认使用 Amazon 托管式密钥 `aws/secretsmanager`。`Sid: "RequireKmsKeyIdParameterOnCreate"`  
****  

```
{
"Version":"2012-10-17",		 	 	 
"Statement": [
  {
      "Sid": "RequireCustomerManagedKeysOnSecrets",
      "Effect": "Deny",
      "Action": [
          "secretsmanager:CreateSecret",
          "secretsmanager:UpdateSecret"
      ],
      "Resource": "*",
      "Condition": {
          "StringLikeIfExists": {
              "secretsmanager:KmsKeyArn": "<key_ARN_of_the_AWS_managed_key>"
          }
      }
  },
  {
      "Sid": "RequireKmsKeyIdParameterOnCreate",
      "Effect": "Deny",
      "Action": "secretsmanager:CreateSecret",
      "Resource": "*",
      "Condition": {
          "Null": {
              "secretsmanager:KmsKeyArn": "true"
          }
      }
  }
]
}
```