다음을 통해 공유


Python용 채팅 문서 보안 시작

검색 증강 생성(RAG) 패턴을 사용하여 채팅 애플리케이션을 구축할 때, 각 사용자가 자신의 사용 권한에 따라 답변을 받는지 확인합니다. 이 문서의 프로세스에 따라 채팅 앱에 문서 액세스 제어를 추가합니다.

  • 권한 있는 사용자: 이 사용자는 채팅 앱의 문서에 포함된 답변에 액세스할 수 있어야 합니다.

    인증이 필요한 액세스 권한이 있는 답변을 보여주는 채팅 앱의 스크린샷

  • 권한 없는 사용자: 이 사용자는 볼 수 있는 권한이 없는 보안 문서의 답변에 액세스할 수 없습니다.

    사용자가 데이터에 액세스할 수 없다는 대답이 포함된 채팅 앱을 보여 주는 스크린샷

메모

문서의 예제 및 지침에 대한 기준으로 하나 이상의 AI 앱 템플릿을 사용합니다. AI 앱 템플릿은 배포하기 쉬운 잘 유지 관리되는 참조 구현을 제공합니다. AI 앱의 고품질 시작점을 보장하는 데 도움이 됩니다.

아키텍처 개요

문서 보안 기능이 없으면 엔터프라이즈 채팅 앱에는 Azure AI Search 및 Azure OpenAI를 사용하여 간단한 아키텍처가 있습니다. 답변은 Azure OpenAI GPT 모델의 응답과 함께 문서가 저장되는 Azure AI Search에 대한 쿼리에서 결정됩니다. 이 간단한 흐름에서는 사용자 인증이 사용되지 않습니다.

아키텍처 다이어그램은 Azure OpenAI의 프롬프트 응답과 함께 문서가 저장되는 Azure AI Search에 대한 쿼리에서 결정된 답변을 보여 줍니다.

문서에 대한 보안을 추가하려면 엔터프라이즈 채팅 앱을 업데이트해야 합니다.

  • Microsoft Entra를 사용하여 채팅 앱에 클라이언트 인증을 추가합니다.
  • 서버 쪽 논리를 추가하여 사용자 및 그룹 액세스 권한으로 검색 인덱스를 채웁니다.

Microsoft Entra ID로 인증한 다음, 해당 인증을 Azure AI Search에 전달하는 사용을 보여 주는 아키텍처 다이어그램입니다.

Azure AI Search는 네이티브 문서 수준 권한을 제공하지 않으며 사용자 권한에 따라 인덱스 내에서 검색 결과를 변경할 수 없습니다. 대신 애플리케이션에서 검색 필터를 사용하여 특정 사용자 또는 특정 그룹에서 문서에 액세스할 수 있도록 할 수 있습니다. 검색 인덱스 내에서 각 문서에는 사용자 또는 그룹 ID 정보를 저장하는 필터링 가능한 필드가 있어야 합니다.

Azure AI Search에서 문서를 보호하기 위해 각 문서에는 결과 집합에 반환되는 사용자 인증이 포함되어 있음을 보여 주는 아키텍처 다이어그램이 있습니다.

권한 부여는 Azure AI Search에 기본적으로 포함되지 않으므로 사용자 또는 그룹 정보를 보관할 필드를 추가한 다음 일치하지 않는 문서에 필터링해야 합니다. 이 기술을 구현하려면 다음을 수행해야 합니다.

  • 문서 액세스 권한이 있는 사용자 또는 그룹의 세부 정보를 저장하는 전용 문서 액세스 제어 필드를 인덱스로 만듭니다.
  • 문서의 액세스 제어 필드를 관련 사용자 또는 그룹 세부 정보로 채웁니다.
  • 사용자 또는 그룹 액세스 권한이 변경되면 이 액세스 제어 필드를 업데이트합니다.

인덱스 업데이트가 인덱서로 예약된 경우, 다음 인덱서 작업에서 변경 내용이 포착됩니다. 인덱서를 사용하지 않는 경우 수동으로 다시 인덱싱해야 합니다.

이 문서에서는 검색 관리자가 실행하는 예제 스크립트를 사용하여 Azure AI Search에서 문서를 보호하는 프로세스를 수행할 수 있습니다. 스크립트는 단일 문서를 단일 사용자 ID와 연결합니다. 이러한 스크립트를 사용하고 고유한 보안 및 프로덕션 요구 사항을 적용하여 요구 사항에 맞게 확장할 수 있습니다.

보안 구성 확인

이 솔루션은 이 샘플에서 문서 보안에 필요한 기능을 켜는 부울 환경 변수를 제공합니다.

매개 변수 목적
AZURE_USE_AUTHENTICATION true설정하면 사용자가 채팅 앱 및 Azure App Service 인증에 로그인할 수 있습니다. 채팅 앱 개발자 설정 Use oid security filter에서 을 사용하도록 설정합니다.
AZURE_ENFORCE_ACCESS_CONTROL true설정하면 모든 문서 액세스에 대한 인증이 필요합니다. UI에서 사용하지 않도록 설정할 수 없도록 OID(개체 ID) 및 그룹 보안에 대한 개발자 설정이 켜지고 비활성화됩니다.
AZURE_ENABLE_GLOBAL_DOCUMENTS_ACCESS true설정하면 액세스 제어가 필요한 경우에도 인증된 사용자가 액세스 제어가 할당되지 않은 문서를 검색할 수 있습니다. 이 매개 변수는 AZURE_ENFORCE_ACCESS_CONTROL 사용하도록 설정된 경우에만 사용해야 합니다.
AZURE_ENABLE_UNAUTHENTICATED_ACCESS true설정하면 이 설정을 사용하면 액세스 제어가 적용되는 경우에도 인증되지 않은 사용자가 앱을 사용할 수 있습니다. 이 매개 변수는 AZURE_ENFORCE_ACCESS_CONTROL 사용하도록 설정된 경우에만 사용해야 합니다.

다음 섹션을 사용하여 이 샘플에서 지원되는 보안 프로필을 이해합니다. 이 문서에서는 Enterprise 프로필을 구성합니다.

Enterprise: 필수 계정 + 문서 필터

사이트 의 각 사용자는 로그인해야 합니다. 사이트에는 모든 사용자에게 공개되는 콘텐츠가 포함되어 있습니다. 문서 수준 보안 필터는 모든 요청에 적용됩니다.

환경 변수:

  • AZURE_USE_AUTHENTICATION=true
  • AZURE_ENABLE_GLOBAL_DOCUMENTS_ACCESS=true
  • AZURE_ENFORCE_ACCESS_CONTROL=true

혼합 사용: 선택적 계정 + 문서 필터

사이트 의 각 사용자는 로그인할 수 있습니다. 사이트에는 모든 사용자에게 공개되는 콘텐츠가 포함되어 있습니다. 문서 수준 보안 필터는 모든 요청에 적용됩니다.

환경 변수:

  • AZURE_USE_AUTHENTICATION=true
  • AZURE_ENABLE_GLOBAL_DOCUMENTS_ACCESS=true
  • AZURE_ENFORCE_ACCESS_CONTROL=true
  • AZURE_ENABLE_UNAUTHENTICATED_ACCESS=true

필수 구성 요소

개발 컨테이너 환경은 이 문서를 완료하는 데 필요한 모든 종속성 사용할 수 있습니다. GitHub Codespaces(브라우저)에서 또는 Visual Studio Code를 사용하여 로컬로 개발 컨테이너를 실행할 수 있습니다.

이 문서를 사용하려면 다음 필수 구성 요소가 필요합니다.

선호하는 개발 환경에 따라 더 많은 필수 구성 요소가 필요합니다.

개발 환경 열기

다음 지침을 사용하여 이 문서를 완료하는 데 필요한 모든 종속성을 포함하는 미리 구성된 개발 환경을 배포합니다.

GitHub에서 관리하는 개발 컨테이너를 실행하며, 사용자는 GitHub Codespaces를 통해 웹용 Visual Studio Code를 인터페이스로 사용할 수 있습니다. 가장 간단한 개발 환경의 경우 이 문서를 완료하기 위해 올바른 개발자 도구와 종속성이 미리 설치되도록 GitHub Codespaces를 사용합니다.

중요하다

모든 GitHub 계정은 두 개의 핵심 인스턴스를 사용하여 매월 최대 60시간 동안 GitHub Codespaces를 사용할 수 있습니다. 자세한 내용은 GitHub Codespaces 월별 포함된 스토리지 및 코어 시간참조하세요.

  1. 프로세스를 시작하여 main GitHub 리포지토리의 분기에 새 GitHub 코드스페이스를 만듭니다.

  2. 다음 단추를 마우스 오른쪽 버튼으로 클릭하고, 새 창에서 링크 열기를 선택하여 개발 환경과 설명서를 동시에 사용할 수 있도록 합니다.

    GitHub Codespaces에서 엽니다.

  3. 코드스페이스 만들기 페이지에서 코드스페이스 구성 설정을 검토한 다음, 새 코드스페이스만들기 선택합니다.

    새 코드스페이스를 만들기 전에 확인 화면을 보여 주는 스크린샷

  4. 코드스페이스가 시작될 때까지 기다립니다. 이 시작 프로세스는 몇 분 정도 걸릴 수 있습니다.

  5. 화면 아래쪽의 터미널에서 Azure 개발자 CLI를 사용하여 Azure에 로그인합니다.

    azd auth login
    
  6. 인증 프로세스를 완료합니다.

  7. 이 문서의 나머지 작업은 이 개발 컨테이너의 컨텍스트에서 수행됩니다.

Azure CLI를 사용하여 필요한 정보 가져오기

다음 Azure CLI 명령을 사용하여 구독 ID 및 테넌트 ID를 가져옵니다. AZURE_TENANT_ID 값으로 사용할 값을 복사합니다.

az account list --query "[].{subscription_id:id, name:name, tenantId:tenantId}" -o table

테넌트의 조건부 액세스 정책에 대한 오류가 발생하면 조건부 액세스 정책이 없는 두 번째 테넌트가 필요합니다.

  • 사용자 계정과 연결된 첫 번째 테넌트는 AZURE_TENANT_ID 환경 변수에 사용됩니다.
  • 조건부 액세스가 없는 두 번째 테넌트는 AZURE_AUTH_TENANT_ID 환경 변수가 Microsoft Graph에 액세스하는 데 사용됩니다. 조건부 액세스 정책을 사용하는 테넌트에 대해 조건부 액세스 정책이 없는 두 번째 테넌트 ID를 찾거나 새 테넌트 를 생성하십시오.

환경 변수 설정

  1. 다음 명령을 실행하여 Enterprise 프로필에 대한 애플리케이션을 구성합니다.

    azd env set AZURE_USE_AUTHENTICATION true
    azd env set AZURE_ENABLE_GLOBAL_DOCUMENTS_ACCESS true
    azd env set AZURE_ENFORCE_ACCESS_CONTROL true
    
  2. 다음 명령을 실행하여 테넌트(사용자가 호스트된 애플리케이션 환경에 로그인할 수 있는 권한을 부여)를 설정합니다. <YOUR_TENANT_ID> 테넌트 ID로 바꿉니다.

    azd env set AZURE_TENANT_ID <YOUR_TENANT_ID>
    

메모

사용자 테넌트에 조건부 액세스 정책이 있는 경우 인증 테넌트을(를) 지정해야 합니다.

Azure에 채팅 앱 배포

배포는 다음 단계로 구성됩니다.

  • Azure 리소스를 만듭니다.
  • 문서를 업로드합니다.
  • Microsoft Entra ID 앱(클라이언트 및 서버)을 만듭니다.
  • 호스팅 리소스에 대한 아이덴티티 기능을 활성화합니다.
  1. 다음 Azure Developer CLI 명령을 실행하여 Azure 리소스를 프로비전하고 소스 코드를 배포합니다.

    azd up
    
  2. 다음 표를 사용하여 AZD 배포 프롬프트에 응답합니다.

    프롬프트 대답
    환경 이름 별칭과 앱과 같은 식별 정보를 포함하는 짧은 이름을 사용하세요. 그리고 예는 tjones-secure-chat입니다.
    구독 리소스를 만들 구독을 선택합니다.
    Azure 리소스의 위치 가까운 위치를 선택합니다.
    documentIntelligentResourceGroupLocation 위치 가까운 위치를 선택합니다.
    openAIResourceGroupLocation 위치 가까운 위치를 선택합니다.

    앱이 배포된 후 5~10분 정도 기다렸다가 앱을 시작할 수 있습니다.

  3. 애플리케이션이 성공적으로 배포되면 터미널에 URL이 나타납니다.

  4. (✓) Done: Deploying service webapp 레이블이 지정된 URL을 선택하여 브라우저에서 채팅 애플리케이션을 엽니다.

    채팅 입력에 대한 몇 가지 제안과 질문을 입력할 채팅 텍스트 상자가 있는 브라우저의 채팅 앱을 보여 주는 스크린샷

  5. 앱 인증 팝업에 동의합니다.

  6. 채팅 앱이 나타나면 오른쪽 위 모서리에 사용자가 로그인되어 있음을 알 수 있습니다.

  7. 개발자 설정을 열고 두 가지 옵션이 선택된 상태이며 변경할 수 없음을 확인하십시오.

    • oid 보안 필터를 사용
    • 그룹 보안 필터 사용
  8. "제품 관리자는 무엇을 합니까?"라는 질문에 해당하는 카드를 선택하십시오..

  9. 다음과 같은 대답을 얻을: 제공 된 소스는 Contoso 전자에서 제품 관리자의 역할에 대 한 특정 정보를 포함 하지 않습니다.

    브라우저에서 답변을 반환할 수 없음을 보여주는 채팅 앱의 스크린샷

사용자가 문서에 접근할 수 있도록 열기

답변을 얻을 수 있도록 정확한 문서에 대한 사용 권한을 켭니다. 다음과 같은 몇 가지 정보가 필요합니다.

  • Azure Storage
    • 계정 이름
    • 컨테이너 이름
    • role_library.pdf에 대한 Blob/문서 URL
  • Microsoft Entra ID의 사용자 ID

이 정보가 알려지면 oids 문서에 대한 Azure AI Search 인덱스 role_library.pdf 필드를 업데이트합니다.

스토리지에 있는 문서의 URL 가져오기

  1. 프로젝트의 루트에 있는 .azure 폴더에서 환경 디렉터리를 찾고 해당 디렉터리로 .env 파일을 엽니다.

  2. AZURE_STORAGE_ACCOUNT 항목을 검색하고 해당 값을 복사합니다.

  3. 다음 Azure CLI 명령을 사용하여 role_library.pdf 컨테이너에서 content Blob의 URL을 가져옵니다.

    az storage blob url \
        --account-name <REPLACE_WITH_AZURE_STORAGE_ACCOUNT \
        --container-name 'content' \
        --name 'role_library.pdf' 
    
    매개 변수 목적
    --account-name Azure Storage 계정 이름입니다.
    --container-name 이 샘플의 컨테이너 이름은 content.
    --이름 이 단계의 Blob 이름은 role_library.pdf.
  4. 나중에 사용할 Blob URL을 복사합니다.

사용자 ID 가져오기

  1. 채팅 앱에서 개발자 설정선택합니다.
  2. ID 토큰 클레임 섹션에서 objectidentifier 매개 변수를 복사합니다. 이 매개 변수는 다음 섹션에서 USER_OBJECT_ID으로 알려져 있습니다.
  1. 다음 스크립트를 사용하여 oids 대한 Azure AI Search의 role_library.pdf 필드를 변경하여 액세스할 수 있도록 합니다.

    ./scripts/manageacl.sh \
        -v \
        --acl-type oids \
        --acl-action add \
        --acl <REPLACE_WITH_YOUR_USER_OBJECT_ID> \
        --url <REPLACE_WITH_YOUR_DOCUMENT_URL>
    
    매개 변수 목적
    -v 장황한 출력.
    --acl-type 그룹 또는 사용자 OID: oids.
    --acl-action 검색 인덱스 필드에 추가합니다. 다른 옵션으로는 remove, remove_alllist.
    --acl 그룹 또는 사용자 USER_OBJECT_ID.
    --url Azure Storage의 파일 위치(예: https://MYSTORAGENAME.blob.core.windows.net/content/role_library.pdf.) CLI 명령에서 URL을 따옴표로 묶지 마세요.
  2. 이 명령의 콘솔 출력은 다음과 같습니다.

    Loading azd .env file from current environment...
    Creating Python virtual environment "app/backend/.venv"...
    Installing dependencies from "requirements.txt" into virtual environment (in quiet mode)...
    Running manageacl.py. Arguments to script: -v --acl-type oids --acl-action add --acl 00000000-0000-0000-0000-000000000000 --url https://mystorage.blob.core.windows.net/content/role_library.pdf
    Found 58 search documents with storageUrl https://mystorage.blob.core.windows.net/content/role_library.pdf
    Adding acl 00000000-0000-0000-0000-000000000000 to 58 search documents
    
  3. 필요에 따라 다음 명령을 사용하여 Azure AI Search의 파일에 대한 권한이 나열되는지 확인합니다.

    ./scripts/manageacl.sh \
        -v \
        --acl-type oids \
        --acl-action list \
        --acl <REPLACE_WITH_YOUR_USER_OBJECT_ID> \
        --url <REPLACE_WITH_YOUR_DOCUMENT_URL>
    
    매개 변수 목적
    -v 장황한 출력.
    --acl-type 그룹 또는 사용자 OID: oids.
    --acl-action 검색 인덱스 필드 oids을 나열하세요. 다른 옵션으로는 remove, remove_alllist.
    --acl 그룹 또는 사용자의 USER_OBJECT_ID 매개 변수입니다.
    --url 그 위치는 https://MYSTORAGENAME.blob.core.windows.net/content/role_library.pdf등으로 표시됩니다. CLI 명령에서 URL을 따옴표로 묶지 마세요.
  4. 이 명령의 콘솔 출력은 다음과 같습니다.

    Loading azd .env file from current environment...
    Creating Python virtual environment "app/backend/.venv"...
    Installing dependencies from "requirements.txt" into virtual environment (in quiet mode)...
    Running manageacl.py. Arguments to script: -v --acl-type oids --acl-action view --acl 00000000-0000-0000-0000-000000000000 --url https://mystorage.blob.core.windows.net/content/role_library.pdf
    Found 58 search documents with storageUrl https://mystorage.blob.core.windows.net/content/role_library.pdf
    [00000000-0000-0000-0000-000000000000]
    

    출력의 끝에 있는 배열에는 USER_OBJECT_ID 매개 변수가 포함되며 Azure OpenAI를 사용하여 답변에 문서가 사용되는지 여부를 확인하는 데 사용됩니다.

Azure AI Search에 USER_OBJECT_ID가 포함되어 있는지 확인합니다.

  1. Azure Portal 열고 AI Search검색합니다.

  2. 목록에서 검색 리소스를 선택합니다.

  3. 검색 관리>인덱스를 선택합니다.

  4. gptkbindex선택하세요.

  5. 보기>JSON 보기선택합니다.

  6. JSON을 다음 JSON으로 교체합니다.

    {
      "search": "*",
      "select": "sourcefile, oids",
      "filter": "oids/any()"
    }
    

    이 JSON은 oids 필드에 값이 있는 모든 문서를 검색하고 sourcefileoids 필드를 반환합니다.

  7. role_library.pdf에 OID가 없는 경우, Azure Search 섹션에서 "문서에 대한 사용자 액세스 제공" 부분으로 돌아가 단계를 완료하십시오.

문서에 대한 사용자 액세스 확인

단계를 완료했지만 정답이 보이지 않는 경우 USER_OBJECT_ID대한 Azure AI Search에서 role_library.pdf 매개 변수가 올바르게 설정되었는지 확인합니다.

  1. 채팅 앱으로 돌아갑니다. 다시 로그인해야 할 수도 있습니다.

  2. Azure OpenAI 답변에서 role_library 콘텐츠가 사용되도록 동일한 쿼리를 입력합니다. What does a product manager do?.

  3. 이제 역할 라이브러리 문서의 적절한 답변이 포함된 결과를 봅니다.

    응답이 반환되었음을 보여 주는 브라우저의 채팅 앱을 보여 주는 스크린샷

리소스 정리

다음 단계에서는 사용한 리소스를 정리하는 과정을 안내합니다.

Azure 리소스 정리

이 문서에서 만든 Azure 리소스는 Azure 구독에 청구됩니다. 나중에 이러한 리소스가 필요하지 않은 경우 더 많은 요금이 발생하지 않도록 해당 리소스를 삭제합니다.

다음 Azure Developer CLI 명령을 실행하여 Azure 리소스를 삭제하고 소스 코드를 제거합니다.

azd down --purge

GitHub Codespaces 및 Visual Studio Code 정리

다음 단계에서는 사용한 리소스를 정리하는 과정을 안내합니다.

GitHub Codespaces 환경을 삭제하면 계정에 대해 얻을 수 있는 코어별 무료 사용 시간 혜택을 최대화할 수 있습니다.

중요하다

GitHub 계정의 자격에 대한 자세한 내용은 GitHub Codespaces 월별 포함된 스토리지 및 코어 시간참조하세요.

  1. GitHub Codespaces 대시보드에 로그인하세요.

  2. Azure-Samples/azure-search-openai-demo GitHub 리포지토리에서 제공되는 현재 실행 중인 코드스페이스를 찾습니다.

    상태 및 템플릿을 포함하여 실행 중인 모든 코드스페이스를 보여 주는 스크린샷

  3. 코드스페이스에 대한 상황에 맞는 메뉴를 열고 삭제선택합니다.

    삭제 옵션이 강조 표시된 단일 코드스페이스의 상황에 맞는 메뉴를 보여 주는 스크린샷

도움 받기

이 샘플 리포지토리는 문제 해결 정보제공합니다.

문제 해결

이 섹션에서는 이 문서와 관련된 문제에 대한 문제 해결을 제공합니다.

인증 테넌트 정보 제공

인증이 호스팅 애플리케이션과 별도의 테넌트에 있는 경우 다음 프로세스를 사용하여 해당 인증 테넌트를 설정해야 합니다.

  1. 다음 명령을 실행하여 인증 테넌트에 두 번째 테넌트를 사용하도록 샘플을 구성합니다.

    azd env set AZURE_AUTH_TENANT_ID <REPLACE-WITH-YOUR-TENANT-ID>
    
    매개 변수 목적
    AZURE_AUTH_TENANT_ID AZURE_AUTH_TENANT_ID 설정되면 앱을 호스트하는 테넌트입니다.
  2. 다음 명령을 사용하여 솔루션을 다시 배포합니다.

    azd up
    
  • Azure OpenAI 모범 사례 솔루션 아키텍처를 사용하여 채팅 앱을 빌드합니다.
  • Azure AI Search을 사용하여 생성 AI 앱에서 액세스 제어를 배우십시오.
  • Azure API Management사용하여 엔터프라이즈급 Azure OpenAI 솔루션을 빌드합니다.
  • Azure AI Search:하이브리드 검색 및 순위 기능을 사용하여 벡터 검색 성능 향상을 참조하세요.