Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Azure Active Directory - IDW10106: The 'ClientId' option must be provided.

아래의 글에서,

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

ConfigureServices의 코드를 아래와 같은 식으로 구성하는데요,

public void ConfigureServices(IServiceCollection services)
{
    services.AddAuthentication(OpenIdConnectDefaults.AuthenticationScheme) // OpenIdConnectDefaults.AuthenticationScheme == "OpenIdConnect"
            .AddMicrosoftIdentityWebApp(Configuration.GetSection("AzureAd"));

    // ...[생략]...
}

appsettings.json의 AzureAd 설정을 재사용하기 위해 다음과 같이 코드를 바꿨더니,

IConfiguration aadSection = Configuration.GetSection("AzureAd");

services.AddAuthentication("OpenIdConnect")
    .AddMicrosoftIdentityWebApp(aadSection);

다음과 같은 오류가 발생합니다. ^^;

An unhandled exception occurred while processing the request.
ArgumentNullException: IDW10106: The 'ClientId' option must be provided.
Microsoft.Identity.Web.MergedOptionsValidation.Validate(MergedOptions options)

Stack Query Cookies Headers Routing
ArgumentNullException: IDW10106: The 'ClientId' option must be provided.
Microsoft.Identity.Web.MergedOptionsValidation.Validate(MergedOptions options)
Microsoft.Identity.Web.MicrosoftIdentityWebAppAuthenticationBuilderExtensions+<>c__DisplayClass5_0.<AddMicrosoftIdentityWebAppInternal>b__2(OpenIdConnectOptions options, IServiceProvider serviceProvider, IOptionsMonitor<MergedOptions> mergedOptionsMonitor, IOptionsMonitor<MicrosoftIdentityOptions> msIdOptionsMonitor, IOptions<MicrosoftIdentityOptions> msIdOptions)
Microsoft.Extensions.Options.ConfigureNamedOptions<TOptions, TDep1, TDep2, TDep3, TDep4>.Configure(string name, TOptions options)
Microsoft.Extensions.Options.OptionsFactory<TOptions>.Create(string name)
Microsoft.Extensions.Options.OptionsMonitor<TOptions>+<>c__DisplayClass11_0.<Get>b__0()
System.Lazy<T>.ViaFactory(LazyThreadSafetyMode mode)
System.Lazy<T>.ExecutionAndPublication(LazyHelper executionAndPublication, bool useDefaultConstructor)
System.Lazy<T>.CreateValue()
System.Lazy<T>.get_Value()
Microsoft.Extensions.Options.OptionsCache<TOptions>.GetOrAdd(string name, Func<TOptions> createOptions)
Microsoft.Extensions.Options.OptionsMonitor<TOptions>.Get(string name)
Microsoft.AspNetCore.Authentication.AuthenticationHandler<TOptions>.InitializeAsync(AuthenticationScheme scheme, HttpContext context)
Microsoft.AspNetCore.Authentication.AuthenticationHandlerProvider.GetHandlerAsync(HttpContext context, string authenticationScheme)
Microsoft.AspNetCore.Authentication.AuthenticationMiddleware.Invoke(HttpContext context)
Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)

원인이 좀 희한합니다. GetSection이 반환하는 타입이 Microsoft.Extensions.Configuration.ConfigurationSection이고, 그것은 IConfiguration, IConfigurationSection을 모두 상속받고 있는데요, 위에서는 IConfiguration으로 넘겨 오류가 발생하지만 IConfigurationSection을 넘기면 또 정상 동작을 하긴 합니다.

// 정상 동작

IConfigurationSection aadSection = Configuration.GetSection("AzureAd"); // Microsoft.Extensions.Configuration.ConfigurationSection 타입 반환

services.AddAuthentication("OpenIdConnect")
    .AddMicrosoftIdentityWebApp(aadSection);

재미있는 건, 사실 (IConfigurationSection이 아닌) IConfiguration으로도 appsettings.json의 내부 값들을 잘 처리합니다.

IConfiguration aadSection = Configuration.GetSection("AzureAd");

string clientId = aadSection.GetValue(typeof(string), "ClientId") as string;
string tenantId = aadSection.GetValue(typeof(string), "TenantId") as string;

내부 코드에서 왜 굳이 IConfigurationSection 타입을 고집하는지 알 수 없지만, 어쨌든 저처럼 IConfiguration으로 넘기면 안 되므로 주의를 요합니다. ^^




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







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

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

비밀번호

댓글 작성자
 




... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...
NoWriterDateCnt.TitleFile(s)
12881정성태12/17/20217271개발 환경 구성: 618. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법 (2)
12880정성태12/16/20217062VS.NET IDE: 170. Visual Studio에서 .NET Core/5+ 역어셈블 소스코드 확인하는 방법
12879정성태12/16/202113302오류 유형: 774. Windows Server 2022 + docker desktop 설치 시 WSL 2로 선택한 경우 "Failed to deploy distro docker-desktop to ..." 오류 발생
12878정성태12/15/20218362개발 환경 구성: 617. 윈도우 WSL 환경에서 같은 종류의 리눅스를 다중으로 설치하는 방법
12877정성태12/15/20217049스크립트: 36. 파이썬 - pymysql 기본 예제 코드
12876정성태12/14/20216844개발 환경 구성: 616. Custom Sources를 이용한 Azure Monitor Metric 만들기
12875정성태12/13/20216557스크립트: 35. python - time.sleep(...) 호출 시 hang이 걸리는 듯한 문제
12874정성태12/13/20216573오류 유형: 773. shell script 실행 시 "$'\r': command not found" 오류
12873정성태12/12/20217693오류 유형: 772. 리눅스 - PATH에 등록했는데도 "command not found"가 나온다면?
12872정성태12/12/20217507개발 환경 구성: 615. GoLang과 Python 빌드가 모두 가능한 docker 이미지 만들기
12871정성태12/12/20217616오류 유형: 771. docker: Error response from daemon: OCI runtime create failed
12870정성태12/9/20216174개발 환경 구성: 614. 파이썬 - PyPI 패키지 만들기 (4) package_data 옵션
12869정성태12/8/20218449개발 환경 구성: 613. git clone 실행 시 fingerprint 묻는 단계를 생략하는 방법
12868정성태12/7/20217020오류 유형: 770. twine 업로드 시 "HTTPError: 400 Bad Request ..." 오류 [1]
12867정성태12/7/20216702개발 환경 구성: 612. 파이썬 - PyPI 패키지 만들기 (3) entry_points 옵션
12866정성태12/7/202114077오류 유형: 769. "docker build ..." 시 "failed to solve with frontend dockerfile.v0: failed to read dockerfile ..." 오류
12865정성태12/6/20216761개발 환경 구성: 611. 파이썬 - PyPI 패키지 만들기 (2) long_description, cmdclass 옵션
12864정성태12/6/20215227Linux: 46. WSL 환경에서 find 명령을 사용해 파일을 찾는 방법
12863정성태12/4/20217146개발 환경 구성: 610. 파이썬 - PyPI 패키지 만들기
12862정성태12/3/20215884오류 유형: 768. Golang - 빌드 시 "cmd/go: unsupported GOOS/GOARCH pair linux /amd64" 오류
12861정성태12/3/20218117개발 환경 구성: 609. 파이썬 - "Windows embeddable package"로 개발 환경 구성하는 방법
12860정성태12/1/20216215오류 유형: 767. SQL Server - 127.0.0.1로 접속하는 경우 "Access is denied"가 발생한다면?
12859정성태12/1/202112394개발 환경 구성: 608. Hyper-V 가상 머신에 Console 모드로 로그인하는 방법
12858정성태11/30/20219654개발 환경 구성: 607. 로컬의 USB 장치를 원격 머신에 제공하는 방법 - usbip-win
12857정성태11/24/20217083개발 환경 구성: 606. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법
12856정성태11/23/20218900.NET Framework: 1121. C# - 동일한 IP:Port로 바인딩 가능한 서버 소켓 [2]
... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...