

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

# Amazon IoT SiteWise 基于身份的策略
<a name="security_iam_service-with-iam-id-based-policies"></a>

IAM 策略支持您在 Amazon IoT SiteWise中控制哪些人可以执行哪些操作。您可以决定允许或不允许哪些操作，并为这些操作设置具体条件。例如，您可以制定规则，规定谁可以查看或更改中的信息 Amazon IoT SiteWise。 Amazon IoT SiteWise 支持特定的操作、资源和条件键。要了解在 JSON 策略中使用的所有元素，请参阅《IAM 用户指南》中的 [IAM JSON 策略元素参考](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference_policies_elements.html)**。

## 策略操作
<a name="security_iam_service-with-iam-id-based-policies-actions"></a>

管理员可以使用 Amazon JSON 策略来指定谁有权访问什么。也就是说，哪个**主体**可以对什么**资源**执行**操作**，以及在什么**条件**下执行。

JSON 策略的 `Action` 元素描述可用于在策略中允许或拒绝访问的操作。在策略中包含操作以授予执行关联操作的权限。

正在执行的策略操作在操作前 Amazon IoT SiteWise 使用以下前缀:`iotsitewise:`. 例如，要授予某人`BatchPutAssetPropertyValue`通过 API 操作将资产属性数据上传到 Amazon IoT SiteWise 的权限，您可以将该`iotsitewise:BatchPutAssetPropertyValue`操作包含在他们的策略中。策略声明必须包含`Action`或`NotAction`元素。 Amazon IoT SiteWise 定义了它自己的一组操作，这些操作描述了您可以使用此服务执行的任务。

要在单个语句中指定多项 操作，请使用逗号将它们隔开，如下所示。

```
"Action": [
  "iotsitewise:action1",
  "iotsitewise:action2"
]
```

您也可以使用通配符 (\$1) 指定多个操作。例如，要指定以单词 `Describe` 开头的所有操作，请包括以下操作。

```
"Action": "iotsitewise:Describe*"
```



要查看 Amazon IoT SiteWise 操作列表，请参阅 *IAM 用户指南 Amazon IoT SiteWise*中[定义的操作](https://docs.amazonaws.cn/service-authorization/latest/reference/list_awsiotsitewise.html#awsiotsitewise-actions-as-permissions)。

### BatchPutAssetPropertyValue 授权
<a name="security_iam_service-with-iam-id-based-policies-batchputassetpropertyvalue-action"></a>

Amazon IoT SiteWise 以一种不寻常的方式授权访问[BatchPutAssetPropertyValue](https://docs.amazonaws.cn/iot-sitewise/latest/APIReference/API_BatchPutAssetPropertyValue.html)操作。对于大多数操作而言，当您允许或拒绝访问时，如果未授予权限，则该操作将返回错误。通过 `BatchPutAssetPropertyValue`，您可以在单个 API 请求中将多个数据条目发送到不同的资产和资产属性。 Amazon IoT SiteWise 会单独向每个数据条目授权。对于请求中未通过授权的任何单个条目， Amazon IoT SiteWise 请在返回的错误列表`AccessDeniedException`中包含一个。 Amazon IoT SiteWise 接收任何授权并成功的条目的数据，即使同一请求中的另一个条目失败也是如此。

**重要**  
在将数据摄取到数据流之前，请执行以下操作：  
如果您使用属性别名来标识数据流，请对 `time-series` 资源进行授权。
如果您使用资产 ID 来识别包含关联资产属性的资产，请对 `asset` 资源进行授权。

## 策略资源
<a name="security_iam_service-with-iam-id-based-policies-resources"></a>

管理员可以使用 Amazon JSON 策略来指定谁有权访问什么。也就是说，哪个**主体**可以对什么**资源**执行**操作**，以及在什么**条件**下执行。

`Resource` JSON 策略元素指定要向其应用操作的一个或多个对象。作为最佳实践，请使用其 [Amazon 资源名称（ARN）](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference-arns.html)指定资源。对于不支持资源级权限的操作，请使用通配符 (\$1) 指示语句应用于所有资源。

```
"Resource": "*"
```



每个 IAM 政策声明都适用于您使用其指定的资源 ARNs。ARN 具有以下一般语法。

```
arn:${Partition}:${Service}:${Region}:${Account}:${ResourceType}/${ResourcePath}
```

有关格式的更多信息 ARNs，请参阅[使用 Amazon 资源名称识别 Amazon 资源 (ARNs)](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference-arns.html)。

例如，要在语句中指定 ID 为 `a1b2c3d4-5678-90ab-cdef-22222EXAMPLE` 的资产，请使用以下 ARN。

```
"Resource": "arn:aws:iotsitewise:region:123456789012:asset/a1b2c3d4-5678-90ab-cdef-22222EXAMPLE"
```

要指定属于特定账户的所有数据流，请使用通配符 (\$1)：

```
"Resource": "arn:aws:iotsitewise:region:123456789012:time-series/*"
```

要指定属于特定账户的所有资产，请使用通配符 (\$1)：

```
"Resource": "arn:aws:iotsitewise:region:123456789012:asset/*"
```

某些 Amazon IoT SiteWise 操作（例如创建资源的操作）无法对特定资源执行。在这些情况下，您必须使用通配符（\$1)。

```
"Resource": "*"
```

要在单个语句中指定多个资源，请 ARNs 用逗号分隔。

```
"Resource": [
  "resource1",
  "resource2"
]
```

要查看 Amazon IoT SiteWise 资源类型及其列表 ARNs，请参阅 *IAM 用户指南 Amazon IoT SiteWise*中[定义的资源类型](https://docs.amazonaws.cn/service-authorization/latest/reference/list_awsiotsitewise.html#awsiotsitewise-resources-for-iam-policies)。要了解可以在哪些操作中指定每个资源的 ARN，请参阅 [Amazon IoT SiteWise定义的操作](https://docs.amazonaws.cn/service-authorization/latest/reference/list_awsiotsitewise.html#awsiotsitewise-actions-as-permissions)。

## 策略条件键
<a name="security_iam_service-with-iam-id-based-policies-conditionkeys"></a>

管理员可以使用 Amazon JSON 策略来指定谁有权访问什么。也就是说，哪个**主体**可以对什么**资源**执行**操作**，以及在什么**条件**下执行。

`Condition` 元素根据定义的条件指定语句何时执行。您可以创建使用[条件运算符](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference_policies_elements_condition_operators.html)（例如，等于或小于）的条件表达式，以使策略中的条件与请求中的值相匹配。要查看所有 Amazon 全局条件键，请参阅 *IAM 用户指南*中的[Amazon 全局条件上下文密钥](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference_policies_condition-keys.html)。

**重要**  
许多条件键是特定于某个资源的，而某些 API 操作会使用多个资源。如果您使用条件键编写策略语句，请使用该语句的 `Resource` 元素指定要将该条件键应用于的资源。如果您没有这样做，该策略可能会完全阻止用户执行操作，因为针对未应用条件键的资源的条件检查失败。如果您不想指定资源，或者如果您已将策略的 `Action` 元素编写为包含多个 API 操作，则必须使用 `...IfExists` 条件类型以确保对不使用条件键的资源忽略条件键。有关更多信息，请参阅[... IfExists *IAM 用户指南*中的条件](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference_policies_elements.html#Conditions_IfExists)。

Amazon IoT SiteWise 定义自己的条件键集，还支持使用一些全局条件键。要查看所有 Amazon 全局条件键，请参阅 *IAM 用户指南*中的[Amazon 全局条件上下文密钥](https://docs.amazonaws.cn/IAM/latest/UserGuide/reference_policies_condition-keys.html)。


**Amazon IoT SiteWise 条件键**  

| 条件键 | 说明 | 类型 | 
| --- | --- | --- | 
| iotsitewise:isAssociatedWithAssetProperty |  数据流是否与资产属性相关联。使用此条件键根据数据流的关联资产属性的存在来定义权限。 示例值：`true`  | 字符串 | 
| iotsitewise:assetHierarchyPath |  资产的层次结构路径，这是一串由正斜杠分 IDs 隔的资产。使用此条件键可根据您账户中所有资产的层次结构子集来定义权限。 示例值：`/a1b2c3d4-5678-90ab-cdef-22222EXAMPLE/a1b2c3d4-5678-90ab-cdef-66666EXAMPLE`  | 字符串 | 
| iotsitewise:propertyId |  资产属性的 ID。使用此条件键可根据指定的资产模型属性来定义权限。此条件键适用于该模型的所有资产。 示例值：`a1b2c3d4-5678-90ab-cdef-33333EXAMPLE`  | 字符串 | 
| iotsitewise:childAssetId |  作为子级关联到其他资产的资产 ID。使用此条件键可根据子资产来定义权限。要根据父资产定义权限，请使用策略语句的资源部分。 示例值：`a1b2c3d4-5678-90ab-cdef-66666EXAMPLE`  | 字符串 | 
| iotsitewise:iam |  列出访问策略时 IAM 身份的 ARN。使用此条件键可定义 IAM 身份的访问策略权限。 示例值：`arn:aws:iam::123456789012:user/JohnDoe`  | 字符串，Null | 
| iotsitewise:propertyAlias |  标识资产属性或数据流的别名。使用此条件键可根据别名来定义权限。  | 字符串 | 
| iotsitewise:user |  列出访问策略时的 IAM Identity Center 用户 ID。使用此条件键可定义 IAM Identity Center 用户的访问策略权限。 示例值：`a1b2c3d4e5-a1b2c3d4-5678-90ab-cdef-aaaaaEXAMPLE`  | 字符串，Null | 
| iotsitewise:group |  列出访问策略时的 IAM Identity Center 组 ID。使用此条件键可定义 IAM Identity Center 组的访问策略权限。 示例值：`a1b2c3d4e5-a1b2c3d4-5678-90ab-cdef-bbbbbEXAMPLE`  | 字符串，Null | 
| iotsitewise:portal |  访问策略中的门户 ID。使用此条件键可根据门户来定义访问策略权限。 示例值：`a1b2c3d4-5678-90ab-cdef-77777EXAMPLE`  | 字符串，Null | 
| iotsitewise:project |  访问策略中的项目 ID 或控制面板的项目 ID。使用此条件键可根据项目来定义控制面板或访问策略权限。 示例值：`a1b2c3d4-5678-90ab-cdef-88888EXAMPLE`  | 字符串，Null | 



要了解可以使用条件键的操作和资源，请参阅[由定义的操作 Amazon IoT SiteWise](https://docs.amazonaws.cn/service-authorization/latest/reference/list_awsiotsitewise.html#awsiotsitewise-actions-as-permissions)。

## 示例
<a name="security_iam_service-with-iam-id-based-policies-examples"></a>



要查看 Amazon IoT SiteWise 基于身份的策略的示例，请参阅。[Amazon IoT SiteWise 基于身份的策略示例](security_iam_id-based-policy-examples.md)