Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Azure Active Directory - The resource principal named api://...[client_id]... was not found in the tenant

App 등록을 아래의 글에 따라,

C# - Azure AD 인증을 지원하는 ASP.NET Core/5+ 웹 애플리케이션 예제 구성
; https://www.sysnet.pe.kr/2/0/12614

다음의 구성 정도로 했습니다.

name: test-auth-webapp
Certificates & secrets: 1개 생성
API permissions: Directry.Read.All, User.Read.All

그다음 아래와 같은 API를 호출했는데,

// MICROSOFT GRAPH – HOW TO IMPLEMENT IAUTHENTICATIONPROVIDER
// ; https://adrianszen.com/2019/06/16/microsoft-graph-how-to-implement-iauthenticationprovider/

public async Task AuthenticateRequestAsync(HttpRequestMessage request)
{
    var clientApplication = ConfidentialClientApplicationBuilder.Create(this.clientId)
        .WithClientSecret(this.clientSecret)
        .WithTenantId(this.tenantId)
        .Build();

    // Client credential flows - Client credential flows in MSAL.NET
    // https://github.com/AzureAD/microsoft-authentication-library-for-dotnet/wiki/Client-credential-flows
    var result = await clientApplication.AcquireTokenForClient(this.appScopes).ExecuteAsync();

    if (request.Headers.Contains("Authorization") == false)
    {
        request.Headers.Add("Authorization", result.CreateAuthorizationHeader());
    }
}

이런 오류가 발생합니다.

AADSTS500011: The resource principal named api://...[client_id]... was not found in the tenant named ...[tenant_id].... This can happen if the application has not been installed by the administrator of the tenant or consented to by any user in the tenant. You might have sent your authentication request to the wrong tenant.

Trace ID: ...[생략]...
Correlation ID: ...[생략]...
Timestamp: ...[생략]...


분명히 Azure Active Directory에서 해당 "[client_id]"와 "[tenant_id]"로 지정된 App을 등록했는데 저렇게 오류가 발생합니다. 이거저거 하다 보니, "Application ID URI"를 생성하지 않으면 저렇게 찾지 못하는 오류가 발생하는데요, ^^; 따라서 해당 App 설정의 "Expose an API" 범주에서,

not_found_in_tenant_1.png

위의 화면처럼 "Application ID URI" 우측에 있는 "Set" 버튼을 눌러주면 "[client_id]"에 해당하는 api 경로가 다음과 같은 식으로 생성됩니다.

api://30dabf24-4603-4dbe-bf29-e09a89c9be72

이제 다시 AcquireTokenForClient 메서드를 호출하면 오류 없이 정상적으로 동작합니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/29/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  173  174  175  176  [177]  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
670정성태2/22/200934557.NET Framework: 124. IIS 7에서 SVC 호스팅 [1]
669정성태2/21/200928512오류 유형: 69. The SQL Server Network Interface library could not register the Service Principal Name (SPN) for the SQL Server service.
668정성태2/21/200933960개발 환경 구성: 35. SQL Express 버전과 User Instance 옵션
667정성태2/14/200945567웹: 9. IE 7. IWebBrowser2 인터페이스 메서드의 Navigate / Navigate2 차이점 [3]파일 다운로드1
666정성태2/12/200932340웹: 8. IE 8: 프로세스와 윈도우의 관계 - LCIE [1]파일 다운로드1
665정성태2/7/200928802웹: 7. Internet Explorer 8 - XHR, XDR, XST, XSRF [1]
664정성태2/5/200924882Windows: 42. Concurrency Runtime
663정성태2/5/200929484.NET Framework: 123. WPF - Arial Narrow 폰트 문제
662정성태2/3/200924592VS.NET IDE: 59. HyperAddin 도구 사용 설명 [1]
661정성태2/3/200928505오류 유형: 68. msxml6r.dll 설치 오류
660정성태2/3/200927293Windows: 41. UAC 보안 취약 [2]
659정성태2/2/200938570오류 유형: 67. ClickOnce 응용 프로그램이 실행되지 않을 때.
658정성태2/1/200930687Team Foundation Server: 30. 소스 서버 보안
657정성태2/1/200933845Windows: 40. Q1 Ultra + Windows 7 베타
656정성태2/1/200934860디버깅 기술: 24. .NET JIT 최적화 코드 생성 제어
655정성태1/31/200931451Windows: 39. IE8 표준 모드 [4]
653정성태1/29/200926269.NET Framework: 122. XML Serializer를 이용한 값 복사: 성능은 어떨까!파일 다운로드1
652정성태1/22/200926867.NET Framework: 121. WPF - PrintTicket provider failed to bind to printer.
651정성태1/20/200924505.NET Framework: 120. 타입이 다른 배열끼리의 변환
650정성태1/19/200936381COM 개체 관련: 21. C/C++ 프로젝트에 /clr 옵션 적용으로 인한 COM 개체 사용 오류
649정성태1/18/200934049Windows: 38. Q1U UMPC에 Windows 7 베타 설치하기
648정성태1/18/200932141Windows: 37. Windows PE를 USB 메모리에 적용
647정성태1/18/200942763Windows: 36. Windows PE ISO 이미지 만들기 [1]
646정성태1/18/200935775디버깅 기술: 23. COMPLUS_ZapDisable - JIT 최적화 코드 생성 제어 [1]
645정성태1/11/200934475Windows: 35. 서명되지 않은 드라이버 로딩 방법
644정성태1/11/200925288Windows: 34. VPC 설치 후기 [2]
... 166  167  168  169  170  171  172  173  174  175  176  [177]  178  179  180  ...