Microsoft MVP성태의 닷넷 이야기
오류 유형: 109. System.ServiceModel.Security.SecurityNegotiationException [링크 복사], [링크+제목 복사],
조회: 29218
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

System.ServiceModel.Security.SecurityNegotiationException

매번 WCF 응용 프로그램(예제도 참 많이 만들어보지만.)을 실행할 때마다 뭔가 하나씩 빼먹는 바람에 예외가 발생해서 고생을 하게 되는데요. 그런 연유로 인해, 다양한 예외 유형 정리는 나중에 다시 해당 프로그래밍을 할 때 도움이 됩니다. 그래서 아래와 같이 정리를 해놓고는 하지요. ^^

WCF 인증서 설정 관련 오류 정리
; https://www.sysnet.pe.kr/2/0/869

이번엔 SecurityNegotiationException 예외 관련해서 기록을 남깁니다.




특히나, 예제를 만들때 주로 WCF 서비스 쪽 설정을 다음과 같이 보안을 꺼버리게 되는데요.

<bindings>
    <basicHttpBinding>
        <binding name="basicHttpBindingConfig">
            <security mode="None" />
        </binding>
    </basicHttpBinding>
      
    <wsHttpBinding>
        <binding name="wsHttpBindingConfig">
            <security mode="None"/>
        </binding>
    </wsHttpBinding>

    <netTcpBinding>
        <binding name="netTcpBindingConfig">
            <security mode="None"/>
        </binding>
    </netTcpBinding>
</bindings>

거의 고정적으로 위의 설정은 web.config(또는 app.config)에 복사하고, BasicHttpBinding만으로 클라이언트 호출을 하다가! WSHttpBinding, NetTcpBinding 쪽의 바인딩을 사용하는 코드를 다음과 같이 사용을 했습니다.

WSHttpBinding wsHttpBinding = new WSHttpBinding();
using (ChannelFactory<IHelloWorld> factory =
    new ChannelFactory<IHelloWorld>(wsHttpBinding,
    new EndpointAddress(wsBindingAddress)))
{
    IHelloWorld world = factory.CreateChannel();

    ICommunicationObject comm = world as ICommunicationObject;
    try
    {
        world.Echo();
        comm.Close();
    }
    catch
    {
        comm.Abort();
    }
}

그래서, 다음과 같은 예외가 발생합니다. ^^

A first chance exception of type 'System.ServiceModel.Security.SecurityNegotiationException' occurred in Unknown Module.

Additional information: Secure channel cannot be opened because security negotiation with the remote endpoint has failed. This may be due to absent or incorrectly specified EndpointIdentity in the EndpointAddress used to create the channel. Please verify the EndpointIdentity specified or implied by the EndpointAddress correctly identifies the remote endpoint.

Unhandled Exception: System.ServiceModel.Security.SecurityNegotiationException:
Secure channel cannot be opened because security negotiation with the remote endpoint has failed. This may be due to absent or incorrectly specified EndpointIdentity in the EndpointAddress used to create the channel. Please verify the EndpointIdentity specified or implied by the EndpointAddress correctly identifies the remote endpoint. ---> System.ServiceModel.FaultException: The message with Action 'http://schemas.xmlsoap.org/ws/2005/02/trust/RST/Issue' cannot be processed at the receiver, due to a ContractFilter mismatch at the EndpointDispatcher. This may be because of either a contract mismatch (mismatched Actions between sender and receiver) or a binding/security mismatch between the sender and the receiver. Check that sender and receiver have the same contract and the same binding
(including security requirements, e.g. Message, Transport, None).
at System.ServiceModel.Security.SecurityUtils.ThrowIfNegotiationFault(Message message, EndpointAddress target)
at System.ServiceModel.Security.SspiNegotiationTokenProvider.GetNextOutgoingMessageBody(Message incomingMessage, SspiNegotiationTokenProviderState sspiState)

--- End of inner exception stack trace ---

Server stack trace:
at System.ServiceModel.Security.IssuanceTokenProviderBase`1.DoNegotiation(TimeSpan timeout)
at System.ServiceModel.Security.SspiNegotiationTokenProvider.OnOpen(TimeSpantimeout)
...[생략]...
at System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage message)

Exception rethrown at [0]:
at System.Runtime.Remoting.Proxies.RealProxy.HandleReturnMessage(IMessage reqMsg, IMessage retMsg)
at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
at ConsoleApplication1.IHelloWorld.Echo()
at ConsoleApplication1.Program.Main(String[] args) in D:\...\ConsoleApplication1\ConsoleApplication1\Program.cs:line 24



아시는 것처럼, WSHttpBinding은 보안 채널 기본값이 Message이기 때문입니다. 서버 측을 꺼버렸으니 클라이언트 측도 다음과 같이 보안을 해제해 주어야 합니다.

WSHttpBinding wsHttpBinding = new WSHttpBinding();
wsHttpBinding.Security.Mode = SecurityMode.None;
using (ChannelFactory<IHelloWorld> factory =
    new ChannelFactory<IHelloWorld>(wsHttpBinding,
    new EndpointAddress(wsBindingAddress)))

재미있는 것은, WSHttpBinding과 NetTcpBinding과의 예외 메시지가 틀리다는 점입니다. NetTcpBinding의 경우에는 다음과 같이 ProtocolException이 발생합니다.

System.ServiceModel.ProtocolException was unhandled
  Message=The requested upgrade is not supported by 'net.tcp://localhost:9001/addrNetTcpBinding'. This could be due to mismatched bindings (for example security enabled on the client and not on the server).
  Source=mscorlib
  StackTrace:
    Server stack trace: 
       at System.ServiceModel.Channels.ConnectionUpgradeHelper.DecodeFramingFault(ClientFramingDecoder decoder, IConnection connection, Uri via, String contentType, TimeoutHelper& timeoutHelper)
       at System.ServiceModel.Channels.ClientFramingDuplexSessionChannel.SendPreamble(IConnection connection, ArraySegment`1 preamble, TimeoutHelper& timeoutHelper)
... [생략] ...
       at System.Runtime.Remoting.Proxies.RealProxy.PrivateInvoke(MessageData& msgData, Int32 type)
       at ConsoleApplication1.IHelloWorld.Echo()
       at ConsoleApplication1.Program.Main(String[] args) in D:\...\ConsoleApplication1\ConsoleApplication1\Program.cs:line 97
... [생략] ...




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







[최초 등록일: ]
[최종 수정일: 4/11/2022]

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

비밀번호

댓글 작성자
 




1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13941정성태6/2/20251733닷넷: 2334. C# - cpuid 명령어를 이용한 CPU 제조사 문자열 가져오기파일 다운로드1
13940정성태6/1/20252065C/C++: 188. C++의 32비트 + Release 어셈블리 코드를 .NET으로 포팅할 때 주의할 점파일 다운로드1
13939정성태5/29/20252816오류 유형: 958. NVIDIA Triton Inference Server - version `GLIBCXX_3.4.32' not found (required by /opt/tritonserver/backends/python/triton_python_backend_stub)
13938정성태5/29/20251973개발 환경 구성: 747. 파이썬 - WSL/docker에 구성한 Triton 예제 개발 환경
13937정성태5/24/20252270개발 환경 구성: 746. Windows + WSL2 환경에서 (tensorflow 등의) NVIDIA GPU 인식
13936정성태5/23/20252053개발 환경 구성: 745. Linux / WSL 환경에 Miniconda 설치하기
13935정성태5/20/20251981오류 유형: 957. 파이썬 - pip 사용 시 "ImportError: cannot import name 'html5lib' from 'pip._vendor'" 오류
13934정성태5/20/20252843스크립트: 77. 파이썬 - 'urllib.request' 모듈의 명시적/암시적 로딩 차이
13933정성태5/19/20252119오류 유형: 956. Visual Studio 2022가 17.12 버전부터 업데이트 되지 않는다면?
13932정성태5/18/20252449스크립트: 76. 파이썬 - Version 문자열 다루기(semver 패키지)
13931정성태5/17/20252778스크립트: 75. 파이썬 - Cython 기본 예제 및 컴파일
13930정성태5/17/20252253개발 환경 구성: 744. 파이썬 - Windows embeddable package 환경에서 외부 패키지 사용하는 방법(ex: UFO² 환경 구성)
13929정성태5/16/20252415오류 유형: 955. 파이썬 - "Windows embeddable package" REPL 환경에서 "NameError: name 'exit' is not defined"
13928정성태5/15/20252558오류 유형: 954. UFO² - "'Invalid URL (POST /v1/chat/completions/chat/completions)'"
13927정성태5/15/20252415오류 유형: 953. OpenAI - The API request of HOST_AGENT failed: OpenAI API request exceeded rate limit: Error code: 429
13926정성태5/14/20253067개발 환경 구성: 743. LLM과 윈도우의 만남 - Desktop AgentOS UFO² 기본 환경 구성
13925정성태5/12/20253049닷넷: 2333. C# - (Console 유형의 프로젝트에서) Clipboard 연동파일 다운로드1
13924정성태5/8/20252742닷넷: 2332. C# - (JetBrains Omea Reader 대상으로) 런타임 시에 메서드 가로채기 [2]파일 다운로드1
13923정성태5/5/20252122스크립트: 74. 파이썬 - C# - Python.NET의 RunSimpleScript, Exec, Eval 차이점파일 다운로드1
13922정성태5/3/20252699스크립트: 73. 파이썬 - Windows embeddable package 버전에서 tkinter 환경 구성
13921정성태5/3/20253274오류 유형: 952. 듀얼 채널 메모리 정렬을 지키지 않은 컴퓨터의 Windows 비정상 종료 현상(Blue Screen) [2]
13920정성태5/3/20253434오류 유형: 951. Typed DataSet 생성 중 "Failed to open a connection to the database" 오류
13919정성태5/2/20252755VS.NET IDE: 201. C# - Typed DataSet(XSD)를 위한 연결 문자열 암호화 [1]파일 다운로드1
13918정성태5/2/20253470VS.NET IDE: 200. C# - app.config 파일의 출력을 Configuration(Debug/Release)에 따라 제어하는 방법파일 다운로드1
13917정성태4/30/20252439VS.NET IDE: 199. Directory.Build.props에 정의한 속성에 대해 Condition 제약으로 값을 변경하는 방법
13916정성태4/23/20252037디버깅 기술: 221. WinDbg 분석 사례 - ASP.NET HttpCookieCollection을 다중 스레드에서 사용할 경우 무한 루프 현상 - 두 번째 이야기
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...