

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

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

**중요**  
지원 종료 공지: 기존 고객은 07/31/2025에 지원이 종료될 때까지 Amazon QLDB를 사용할 수 있습니다. 자세한 내용은 [Amazon QLDB 원장을 Amazon Aurora PostgreSQL로 마이그레이션](https://aws.amazon.com/blogs/database/migrate-an-amazon-qldb-ledger-to-amazon-aurora-postgresql/)을 참조하세요.

혼동된 대리자 문제는 작업을 수행할 권한이 없는 엔터티가 권한이 더 많은 엔터티에게 작업을 수행하도록 강요할 수 있는 보안 문제입니다. 에서 AWS교차 서비스 가장은 혼동된 대리자 문제를 초래할 수 있습니다.

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

Amazon QLDB가 리소스에 다른 서비스를 제공하는 권한을 제한하려면 리소스 정책에서 [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) 및 [https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-sourceaccount](https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_condition-keys.html#condition-keys-sourceaccount) 글로벌 조건 컨텍스트 키를 사용하는 것이 좋습니다. 두 글로벌 조건 컨텍스트 키를 모두 사용하는 경우 `aws:SourceAccount` 값과 `aws:SourceArn` 값의 계정은 동일한 정책 문에서 사용할 경우 동일한 계정 ID를 사용해야 합니다.

다음 표에는 [https://docs.aws.amazon.com/qldb/latest/developerguide/API_ExportJournalToS3.html](https://docs.aws.amazon.com/qldb/latest/developerguide/API_ExportJournalToS3.html) 및 [https://docs.aws.amazon.com/qldb/latest/developerguide/API_StreamJournalToKinesis.html](https://docs.aws.amazon.com/qldb/latest/developerguide/API_StreamJournalToKinesis.html) QLDB API 작업에 사용할 수 있는 값 `aws:SourceArn`이 나와 있습니다. 이러한 작업은 지정한 IAM 역할을 수임하기 위해 AWS Security Token Service (AWS STS)를 호출하기 때문에이 보안 문제의 범위에 속합니다.


****  

| API 작업 | 호출된 서비스 | aws:SourceArn | 
| --- | --- | --- | 
| ExportJournalToS3 | AWS STS ([https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html](https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html)) |  QLDB가 계정의 모든 QLDB 리소스에 대한 역할을 맡을 수 있도록 허용합니다. <pre>arn:aws:qldb:us-east-1:123456789012:*</pre> 현재 QLDB는 저널 내보내기에 대해 이 와일드카드 ARN만 지원합니다.  | 
| StreamsJournalToKinesis | AWS STS ([https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html](https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html)) |  QLDB가 특정 QLDB 스트림에 대한 역할을 맡을 수 있도록 허용합니다. <pre>arn:aws:qldb:us-east-1:123456789012:stream/myExampleLedger/IiPT4brpZCqCq3f4MTHbYy</pre> **참고:** 스트림 리소스가 생성된 후에만 ARN에서 스트림 ID를 지정할 수 있습니다. 이 ARN을 사용하면 단일 QLDB 스트림에만 역할을 사용하도록 허용할 수 있습니다. QLDB가 원장의 모든 QLDB 스트림에 대한 역할을 맡을 수 있도록 허용합니다. <pre>arn:aws:qldb:us-east-1:123456789012:stream/myExampleLedger/*</pre> QLDB가 계정의 모든 QLDB 스트림에 대한 역할을 맡을 수 있도록 허용합니다. <pre>arn:aws:qldb:us-east-1:123456789012:stream/*</pre> QLDB가 계정의 모든 QLDB 리소스에 대한 역할을 맡을 수 있도록 허용합니다. <pre>arn:aws:qldb:us-east-1:123456789012:*</pre>  | 

혼동된 대리인 문제로부터 보호하는 가장 효과적인 방법은 리소스의 전체 ARN이 포함된 `aws:SourceArn` 글로벌 조건 컨텍스트 키를 사용하는 것입니다. 리소스의 전체 ARN을 모르거나 여러 리소스를 지정하는 경우, ARN의 알 수 없는 부분(예: `arn:aws:qldb:us-east-1:123456789012:*`)에 대해 와일드카드 문자(`*`)를 포함한 `aws:SourceArn` 글로벌 조건 컨텍스트 키를 사용합니다.

다음 예는 신뢰 정책에서 IAM 역할이 `aws:SourceArn` 및 `aws:SourceAccount` 전역 조건 컨텍스트 키를 사용하여 혼동된 대리자 문제를 방지하는 방법을 보여줍니다. 이 신뢰 정책을 사용하면 QLDB는 원장 `myExampleLedger`에 대한 계정 `123456789012`의 모든 QLDB 스트림에 대한 역할만 맡을 수 있습니다.

이 정책을 사용하려면 예제의 *us-east-1*, *123456789012*, *myExampleLedger*를 사용자 고유의 정보로 바꾸세요.

```
{
  "Version": "2012-10-17",
  "Statement": {
    "Sid": "ConfusedDeputyPreventionExamplePolicy",
    "Effect": "Allow",
    "Principal": {
      "Service": "qldb.amazonaws.com"
    },
    "Action": [ "sts:AssumeRole" ],
    "Condition": {
      "ArnEquals": {
        "aws:SourceArn": "arn:aws:qldb:us-east-1:123456789012:stream/myExampleLedger/*"
      },
      "StringEquals": {
        "aws:SourceAccount": "123456789012"
      }
    }
  }
}
```