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

C# - HttpClient: Requesting HTTP version 2.0 with version policy RequestVersionExact while HTTP/2 is not enabled.

Fiddler를 비롯해 기타 Proxy 설정과 함께 HttpClient를 사용하면,

// .NET 5
using System;
using System.Net.Http;
using System.Threading.Tasks;

class Program
{
    private static readonly HttpClient _client;

    static Program()
    {
        SocketsHttpHandler handler = new SocketsHttpHandler();
        handler.Proxy = new WebProxy("127.0.0.1:18080", false);

        _client = new HttpClient(handler)
        {
            DefaultVersionPolicy = HttpVersionPolicy.RequestVersionExact,
            DefaultRequestVersion = new Version(2, 0),
        };
    }

    static async Task Main()
    {
        try
        {
            using var response = await _client.GetAsync("http://localhost:5000/");
        }
        catch (HttpRequestException ex)
        {
            Console.WriteLine(ex.ToString());
        }
    }
}

무조건 이런 예외가 발생합니다.

System.Net.Http.HttpRequestException: Requesting HTTP version 2.0 with version policy RequestVersionExact while HTTP/2 is not enabled.
   at System.Net.Http.HttpConnectionPool.SendWithRetryAsync(HttpRequestMessage request, Boolean async, Boolean doRequestAuth, CancellationToken cancellationToken)
   at System.Net.Http.RedirectHandler.SendAsync(HttpRequestMessage request, Boolean async, CancellationToken cancellationToken)
   at System.Net.Http.HttpClient.SendAsyncCore(HttpRequestMessage request, HttpCompletionOption completionOption, Boolean async, Boolean emitTelemetryStartStop, CancellationToken cancellationToken)
   at Program.Main() in C:\temp\ConsoleApp1\Program.cs:line 49

테스트를 해보면, 위의 결과는 127.0.0.1:18080 프록시 서버에 대한 연결조차 하지 않고 발생하는 것을 알 수 있습니다. 즉, 실제로 연결을 하기 전에 요청에 대한 유효함을 판정하는 동안 정책적으로 허용이 안 되어 중단하는 것으로 보입니다. 메시지에 따라 RequestVersionExact로 설정된 것이 문제인데요, RequestVersionOrHigher도 마찬가지의 오류가 발생하고 RequestVersionOrLower 옵션을 설정해야만 정상적으로 프록시 서버에 연결을 시도합니다. 하지만 이 때의 요청은 HTTP/1.1 통신을 시도합니다.

그러니까, HttpClient는 프록시 서버를 사용하는 경우 HTTP/2 통신은 지원하지 않는 것으로 보입니다. (이에 대한 공식 문서는 찾을 수가 없는데, 혹시 아시는 분은 덧글 부탁드립니다. ^^)




참고로, 설령 Proxy 설정을 해서 저 코드가 동작한다고 해도 Fiddler의 경우 아직 HTTP/2를 지원하지 않기 때문에,

Fiddler HTTP/2 support requested
; https://feedback.telerik.com/fiddlercore/1464174-fiddler-http-2-support-requested

(위의 이슈에 대해 "Unplanned"로 평가하고 있습니다.)

어차피 동작을 하지 않습니다.




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







[최초 등록일: ]
[최종 수정일: 1/22/2021]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  125  126  127  [128]  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
2915정성태5/9/201534727개발 환경 구성: 265. TrustedInstaller 권한으로 프로그램 실행시키는 방법 [11]
2914정성태5/9/201531672DDK: 7. 정식 인증서가 있는 경우 Device Driver 서명하는 방법 [2]
2913정성태4/30/201529408.NET Framework: 511. Build 2015 행사에서 소개된 (맥/리눅스/윈도우 용 무료) Visual Studio Code 개발 도구 [8]
2912정성태4/29/201524657오류 유형: 286. VirtualBox에 Windows 8/2012 설치 시 "Error Code: 0x000000C4" 오류 발생
2911정성태4/29/201523233오류 유형: 285. Visual Studio 2015를 제거한 경우 Microsoft.VisualStudio.Web.PageInspector.Loader 어셈블리를 못 찾는 문제 [2]
2910정성태4/29/201527098오류 유형: 284. System.TypeLoadException: Could not load type 'System.Reflection.AssemblySignatureKeyAttribute' from assembly [1]
2909정성태4/29/201523109오류 유형: 283. WCF 연결 오류 - Expected record type 'PreambleAck'
2908정성태4/29/201531201오류 유형: 282. 원격에서 SQL 서버는 연결되지만, SQL Express는 연결되지 않는 경우
2907정성태4/29/201521744.NET Framework: 510. 제네릭(Generic) 인자에 대한 메타데이터 등록 확인
2906정성태4/28/201524017오류 유형: 281. DebugView로 인한 System.Diagnostics.Trace.WriteLine 멈춤(Hang) 현상
2905정성태4/27/201524832오류 유형: 280. HttpResponse.Headers.Add에서 "System.PlatformNotSupportedException: This operation requires IIS integrated pipeline mode." 예외 발생
2904정성태4/27/201529427DDK: 6. ZwTerminateProcess로 프로세스를 종료하는 Device Driver 프로그램 [2]파일 다운로드1
2903정성태4/20/201523407Windows: 110. (무료) 마이크로소프트 온라인 강좌 소개 - Azure에서 제공하는 계정 관리 서비스
2902정성태4/16/201529434Windows: 109. (무료) 마이크로소프트 온라인 강좌 소개 - Active Directory 이해
2901정성태4/15/201526014Windows: 108. (무료) 마이크로소프트 온라인 강좌 소개 - Windows Server 2012 R2 주요 기술 (Hyper-V 관점)
2900정성태3/24/201524992오류 유형: 279. robocopy 오류 - The file cannot be accessed by the system [4]
2899정성태3/24/201532941개발 환경 구성: 264. Visual Studio 2013 솔루션을 2015로 마이그레이션
2898정성태3/24/201523819개발 환경 구성: 263. SharePoint 2013을 Windows Server 2012 R2에 설치
2897정성태3/18/201522164오류 유형: 278. LoadLibrary("...") failed - Invalid access to memory location.
2896정성태3/18/201522013VC++: 90. Visual Studio 2013에서 Visual Basic 6용 ATL Control 제작
2895정성태3/18/201525512VC++: 89. Visual Studio 2015 - auto 반환 타입 및 thread_local 예약어 지원(C++ 11 표준) [2]
2894정성태3/18/201522892.NET Framework: 509. ELEMENT_TYPE_MODIFIER의 조합
2893정성태3/18/201524128오류 유형: 277. command line error MIDL1004: cannot execute C preprocessor cl.exe
2892정성태3/17/201529105오류 유형: 276. robocopy - Logon failure: unknown user name or bad password.
2891정성태3/17/201545040개발 환경 구성: 262. Visual Basic 6 (Enterprise Edition)을 Windows 7 x86에 설치하는 방법 [1]
2890정성태3/17/201526551오류 유형: 275. Internet Explorer - This page can't be displayed
... 121  122  123  124  125  126  127  [128]  129  130  131  132  133  134  135  ...