Microsoft MVP성태의 닷넷 이야기
.NET Framework: 208. WCF - 접속된 클라이언트의 IP 주소 알아내는 방법 [링크 복사], [링크+제목 복사],
조회: 25891
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
WCF - 접속된 클라이언트의 IP 주소 알아내는 방법

WCF를 호출한 클라이언트 측의 IP 주소를 얻는 방법은 아래에 잘 답변이 되어 있습니다.

WCF: can't get client endpoint.Address from server
; http://stackoverflow.com/questions/3316906/wcf-cant-get-client-endpoint-address-from-server

그래서, 다음과 같이 쉽게 가져올 수 있습니다.

var context = OperationContext.Current;
var prop = context.IncomingMessageProperties;
var endpoint = prop[RemoteEndpointMessageProperty.Name] as RemoteEndpointMessageProperty;

string ipText = endPoint.Address;

단지, 약간의 사소한(?) 문제가 있다면 "wsDualHttpBinding"에서는 RemoteEndpointMessageProperty.Address 속성값이 빈 문자열로 나옵니다.

이에 관해서는 다음의 글이 검색되는데요.

"Message Security Anonymous" example + "Duplex" example = no reply?
; http://www.netframeworkdev.com/windows-communication-foundation/message-security-anonymous-example--duplex-example--no-reply-64193.shtml

현재는 MSDN에 없는 내용을 인용해서 아래와 같이 그 원인을 설명해 주고 있습니다.

But according to this:

https://docs.microsoft.com/en-us/dotnet/api/system.servicemodel.channels.remoteendpointmessageproperty

"It appears that the RemoteEndpointMessageProperty is not available when using the WSDualHttpBinding.
The RemoteEndpointMessageProperty uses the HttpApplication.Request.UserHostAddress to return the IP;
however, the HttpContext is not available with WSDualHttpBinding, causing a "Request is not available in the context" exception."


그렇다고 하니... 우회 방법을 찾아봐야 할 텐데요. 몇 가지 테스트를 해보니, Dual 채널의 다른 쪽에 맺어져 있는 URI를 구해서 그것의 Host 속성을 접근하면 IP 또는 컴퓨터 이름을 구할 수는 있었습니다.

if (string.IsNullOrEmpty(endpoint.Address) == true)
{
    string clientIpOrName = System.ServiceModel.OperationContext.Current.Channel.RemoteAddress.Uri.Host;
}




마지막으로, RemoteEndpointMessageProperty가 3.0 SP1 이후에 구현되었기 때문에 3.0까지만 설치되어 있는 환경에서 그대로 사용하다가는 다음과 같이 오류가 발생합니다.

 System.ArgumentException: A property with the name 'System.ServiceModel.Channels.RemoteEndpointMessageProperty' is not present.

   at System.ServiceModel.Channels.MessageProperties.get_Item(String name)
   at WebSiteTest.HelloWorld(String connectionString) in d:\Test\WebSiteTest.svc.cs:line 136
   at SyncInvokeHelloWorld(Object , Object[] , Object[] )
   at System.ServiceModel.Dispatcher.SyncMethodInvoker.Invoke(Object instance, Object[] inputs, Object[]& outputs) 

따라서, 어느 환경에서나 적용가능한 프레임워크 코드 같은 곳에서 사용하는 경우라면, 다음과 같이 선행 검사를 거치는 작업과 함께 실제 RemoteEndpointMessageProperty 타입에 대한 사용을 별도의 메서드로 분리하는 것이 좋습니다.

const string RemoteEndpointMessagePropertyName = "System.ServiceModel.Channels.RemoteEndpointMessageProperty";

if (messageProperties.ContainsKey(RemoteEndpointMessagePropertyName) == true)
{
    object result = messageProperties[RemoteEndpointMessagePropertyName];
    if (result != null)
    {
        string text = GetClientIPAddressText(result);
    }
}

[MethodImpl(MethodImplOptions.NoInlining)]
static string GetClientIPAddressText(object result)
{
    RemoteEndpointMessageProperty endpointProperty = result as RemoteEndpointMessageProperty;
    if (endpointProperty == null)
    {
        return string.Empty;
    }

    return endpointProperty.Address;
}



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

[연관 글]






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

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

비밀번호

댓글 작성자
 



2011-12-31 08시23분
WCF - 접속된 클라이언트의 IP 주소 알아내는 방법 - 두 번째 이야기
; http://www.sysnet.pe.kr/2/0/1213
정성태

... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...
NoWriterDateCnt.TitleFile(s)
12887정성태12/21/20219704오류 유형: 777. OpenCVSharp4를 사용한 프로그램 실행 시 "The type initializer for 'OpenCvSharp.Internal.NativeMethods' threw an exception." 예외 발생
12886정성태12/20/20217582스크립트: 37. 파이썬 - uwsgi의 --enable-threads 옵션 [2]
12885정성태12/20/20217829오류 유형: 776. uwsgi-plugin-python3 환경에서 MySQLdb 사용 환경
12884정성태12/20/20216874개발 환경 구성: 620. Windows 10+에서 WMI root/Microsoft/Windows/WindowsUpdate 네임스페이스 제거
12883정성태12/19/20217741오류 유형: 775. uwsgi-plugin-python3 환경에서 "ModuleNotFoundError: No module named 'django'" 오류 발생
12882정성태12/18/20216860개발 환경 구성: 619. Windows Server에서 WSL을 위한 리눅스 배포본을 설치하는 방법
12881정성태12/17/20217345개발 환경 구성: 618. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법 (2)
12880정성태12/16/20217158VS.NET IDE: 170. Visual Studio에서 .NET Core/5+ 역어셈블 소스코드 확인하는 방법
12879정성태12/16/202113405오류 유형: 774. Windows Server 2022 + docker desktop 설치 시 WSL 2로 선택한 경우 "Failed to deploy distro docker-desktop to ..." 오류 발생
12878정성태12/15/20218481개발 환경 구성: 617. 윈도우 WSL 환경에서 같은 종류의 리눅스를 다중으로 설치하는 방법
12877정성태12/15/20217124스크립트: 36. 파이썬 - pymysql 기본 예제 코드
12876정성태12/14/20216970개발 환경 구성: 616. Custom Sources를 이용한 Azure Monitor Metric 만들기
12875정성태12/13/20216637스크립트: 35. python - time.sleep(...) 호출 시 hang이 걸리는 듯한 문제
12874정성태12/13/20216624오류 유형: 773. shell script 실행 시 "$'\r': command not found" 오류
12873정성태12/12/20217782오류 유형: 772. 리눅스 - PATH에 등록했는데도 "command not found"가 나온다면?
12872정성태12/12/20217597개발 환경 구성: 615. GoLang과 Python 빌드가 모두 가능한 docker 이미지 만들기
12871정성태12/12/20217666오류 유형: 771. docker: Error response from daemon: OCI runtime create failed
12870정성태12/9/20216234개발 환경 구성: 614. 파이썬 - PyPI 패키지 만들기 (4) package_data 옵션
12869정성태12/8/20218533개발 환경 구성: 613. git clone 실행 시 fingerprint 묻는 단계를 생략하는 방법
12868정성태12/7/20217097오류 유형: 770. twine 업로드 시 "HTTPError: 400 Bad Request ..." 오류 [1]
12867정성태12/7/20216763개발 환경 구성: 612. 파이썬 - PyPI 패키지 만들기 (3) entry_points 옵션
12866정성태12/7/202114156오류 유형: 769. "docker build ..." 시 "failed to solve with frontend dockerfile.v0: failed to read dockerfile ..." 오류
12865정성태12/6/20216864개발 환경 구성: 611. 파이썬 - PyPI 패키지 만들기 (2) long_description, cmdclass 옵션
12864정성태12/6/20215326Linux: 46. WSL 환경에서 find 명령을 사용해 파일을 찾는 방법
12863정성태12/4/20217251개발 환경 구성: 610. 파이썬 - PyPI 패키지 만들기
12862정성태12/3/20215979오류 유형: 768. Golang - 빌드 시 "cmd/go: unsupported GOOS/GOARCH pair linux /amd64" 오류
... 16  17  18  19  20  21  22  23  24  25  26  27  28  29  [30]  ...