

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

# 교차 서비스 혼동된 대리자 예방
<a name="cross-service-confused-deputy-prevention"></a>

혼동된 대리자 문제는 작업을 수행할 권한이 없는 엔터티가 권한이 더 많은 엔터티에게 작업을 수행하도록 강요할 수 있는 보안 문제입니다. 에서 AWS교차 서비스 가장은 혼동된 대리자 문제를 초래할 수 있습니다. 교차 서비스 가장은 한 서비스(*직접 호출하는 서비스*)가 다른 서비스(*직접 호출되는 서비스*)를 직접 호출할 때 발생할 수 있습니다. 직접 호출하는 서비스는 다른 고객의 리소스에 대해 액세스 권한이 없는 방식으로 작동하게 권한을 사용하도록 조작될 수 있습니다. 이를 방지하기 위해 AWS 에서는 계정의 리소스에 대한 액세스 권한이 부여된 서비스 위탁자를 사용하여 모든 서비스에 대한 데이터를 보호하는 데 도움이 되는 도구를 제공합니다.

리소스 정책에서 [https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-sourcearn](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-sourcearn) 글로벌 조건 컨텍스트 키를 사용하여 AWS Clean Rooms이 다른 서비스가 리소스에 부여하는 권한을 제한하는 것이 좋습니다. 하나의 리소스만 교차 서비스 액세스와 연결되도록 허용하려는 경우 `aws:SourceArn`을 사용하세요.

혼동된 대리인 문제로부터 보호하는 가장 효과적인 방법은 리소스의 전체 ARN이 포함된 `aws:SourceArn`글로벌 조건 컨텍스트 키를 사용하는 것입니다. 에서는 `sts:ExternalId` 조건 키와 AWS Clean Rooms도 비교해야 합니다.

`aws:SourceArn`의 값은 수임된 역할 멤버십의 ARN으로 설정해야 합니다.

다음 예는 Clean Rooms에서 `aws:SourceArn` 및 AWS글로벌 조건 컨텍스트 키를 사용하여 혼동된 대리자 문제를 방지하는 방법을 보여줍니다.

**참고**  
예제 정책은가 구성된 테이블의 데이터 및 메타데이터에 액세스하는 데 AWS Clean Rooms 사용하는 서비스 역할의 신뢰 정책에 적용됩니다.  
*<query-runner-membership-id>*의 값을 쿼리 실행기의 멤버십 ID로 설정해야 합니다.  
공동 작업의 모든 구성원은 구성된 테이블 메타데이터를 볼 수 있으므로 각 멤버십 ARN이 멤버십 ARNs 목록에 포함되어야 합니다.

**참고**  
 AWS Clean Rooms 콘솔을 통해 서비스 역할이 생성되면 공동 작업의 모든 현재 구성원이 기본적으로 혼동된 대리자 조건에 포함됩니다.  
이미 연결된 테이블을 구성한 공동 작업에 새 멤버를 추가하는 경우 서비스 역할의 혼동된 대리자 조건을 새 멤버의 멤버십 ARN으로 업데이트해야 합니다.  
새 멤버를 추가한 후 서비스 역할의 혼동된 대리자 조건을 업데이트하지 않으면 해당 새 멤버는 해당 역할을 사용하여 검색 AWS Clean Rooms 된의 정보에 액세스할 수 없습니다.

------
#### [ JSON ]

****  

```
{
    "Version":"2012-10-17",		 	 	 
    "Statement": [
        {
            "Sid": "AllowIfExternalIdMatches",
            "Effect": "Allow",
            "Principal": {
                "Service": "cleanrooms.amazonaws.com"
            },
            "Action": "sts:AssumeRole",
            "Condition": {
                "StringLike": {
                    "sts:ExternalId": "arn:aws:*:us-east-1:*:dbuser:*/<query-runner-membership-id>*"
                }
            }
        },
        {
            "Sid": "AllowIfSourceArnMatches",
            "Effect": "Allow",
            "Principal": {
                "Service": "cleanrooms.amazonaws.com"
            },
            "Action": "sts:AssumeRole",
            "Condition": {
                "ForAnyValue:ArnEquals": {
                    "aws:SourceArn": [
                        "arn:aws:cleanrooms:us-east-1:111122223333:membership/<member-1-membership-id>",
                        "arn:aws:cleanrooms:us-east-1:444455556666:membership/<member-2-membership-id>"
                    ]
                }
            }
        }
    ]
}
```

------