Microsoft MVP성태의 닷넷 이야기
WCF channel faulted 관련 [링크 복사], [링크+제목 복사],
조회: 13748
글쓴 사람
임동찬 (dngchn.im at samsung.com)
홈페이지
첨부 파일
 

https://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&detail=1&wid=535

위 아티클의 마지막 부분에 대한 질문입니다.
faulted 이벤트 핸들러의 첫번째 인자인 sender를 IClientChannel 타입으로 형 변환하여,
channel 관련 정보를 얻으려고 합니다.
정확히 필요한 정보는 해당 채널의 Address 입니다.
디버그 중간에는 Visual Studio의 quick view를 통해
((System.ServiceModel.Channels.ServiceChannelProxy)(((System.Runtime.Remoting.Proxies.__TransparentProxy)(((System.Runtime.Remoting.Proxies.__TransparentProxy)(sender as IClientChannel))))._rp)).serviceChannel.RemoteAddress 임을 확인하였습니다.
...
그러나 실제 이 정보를 코드에서 이용하려고 하면 안됩니다. TT...
일단
System.Runtime.Remoting.Proxies에서 __TransparentProxy를 인식 못합니다.
어떻게 하면 좋을까요?








[최초 등록일: ]
[최종 수정일: 2/21/2011]


비밀번호

댓글 작성자
 



2011-02-24 09시25분
너무 답변이 늦은 게 아닌지 모르겠습니다. 요근래, 방과후에도 너무 바빠서. ^^;

일단, 안해보고 답변을 드리면.

디버거에서는 private 등에 대해서 모두 파헤치기 때문에 잘 보일 수 있습니다. 그런 경우에는 어쩌면 약간의 리플렉션을 동원해야 할 수도 있습니다.

방과 후 쌓인 숙제가 많아서... 이번주내로 직접 해보고 답변다시 달겠습니다. ^^
정성태
2011-03-04 11시17분
음... 직접 해봤는데... 어떻게 RemoteAddress를 가져왔는지 잘 이해가 안되는데요. 제가 본 debug 창에서는 Proxies 개념 같은 것이 나오지 않았습니다. 혹시, 클라이언트 proxy 개체에 대해서 본 건가요? (제 글에서는 서버 측을 기준으로 한 것입니다.)

일단, RemoteAddress 값은 메서드 호출 시에 다음과 같이 해서 가져올 수 있습니다.

RemoteEndpointMessageProperty prop = OperationContext.Current.IncomingMessageProperties[RemoteEndpointMessageProperty.Name]
 as RemoteEndpointMessageProperty;
 string addr = string.Format("{0}:{1}", prop.Address, prop.Port);

하지만, Faulted/Closed 에서는 OperationContext.Current 가 null 이기 때문에 아래의 글에서 설명한 것처럼,

WCF - PerSession 에서의 클라이언트 연결 관리
; http://www.sysnet.pe.kr/2/0/535

메서드 호출 시에, 전역 변수에 세션 ID와 함께 주소를 보관한 후 Faulted/Closed 에서는 세션 ID로 그 값을 조회하는 것이 바람직할 것 같습니다.
정성태

... 61  62  63  64  65  66  67  68  69  [70]  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
785정성우12/16/200811582Vista 환경에서 VB6로 개발한 어플리케이션이 IE 통해서는 런칭이 안됩니다.. [4]
783서광원11/20/200812322.NET 어셈블리를 COM에서 사용하도록 변경 했을때 배포는 어떻게 해야 하나요? [3]
782김용환10/14/200812641웹서비스에서 캐시를 사용하고 싶습니다. [3]
781이수정9/5/200810892visual studio 2008 관련 질문입니다. [2]
776신현창8/5/200811195VS2005로 실행시 갑자기 COM+ 등록이 안됩니다. [1]
775땡초7/21/200811421조언을 구하고저 합니다. [2]
774남호진7/19/200811785Visual Studio 2005나 2008에서 서버탐색기에연결된 데이터에서 정보를 끌어... [2]
773지워니7/17/200814036웹서비스로 db2의 데이터가 오질 않아요. [1]
984이영구7/16/201113991    답변글 [답변]: 웹서비스로 db2의 데이터가 오질 않아요.
772다자래7/15/200811304스레드와 이벤트를 이용해서 mssql 서버의 저장프로시져의 레코드 진행률을 표현하는 프로그래스바를 구현하려고하는데....막막 [1]
771guest6/26/200811109[WCF] Self host 만드는 방법. [2]파일 다운로드1
770조조5/27/200810849스마트클라이언트에서 stand-alone 형태를 임베디드형태로 변환시 문제.. [1]
769제영한5/20/200810879배포프로젝트에 대한 조언을 구합니다. [2]
767김형중5/6/200811935RMclock 관련 문의 입니다. [1]
766정성태4/28/200812581[데브피아 Q&A 모음] 2008-04-21 ~ 2008-04-24
764정성태4/21/200813406[데브피아 Q&A 모음] 2008-04-14 ~ 2008-04-18 [2]
763단테4/17/200811139COM 객체 생성하는 방법
765정성태4/21/200811831    답변글 [답변]: CreateInstance를 부르시는 것이 추천됩니다.
762이민지4/16/200814852ClickOnce 실행 시 Internet Explorer 7.0에서 에러 메세지 출력 [1]
761이민지4/16/200811386ClickOnce로 배포를 하다가 생긴 문제에 대해 질문드립니다. [1]
760한귀순4/15/200812101DataSet 의 designer.cs [2]
759정성태4/14/200812385[데브피아 Q&A 모음] 2008-04-04 ~ 2008-04-12
7573/28/200899142008 Server, Vista 에서 RDS 지원? [4]
756손승휘3/24/200813633Microsoft Web Browser OCX 부분이 안전하지 않는 ACTIVEX로 IE에서 인식되어는 점 [1]
754단테3/19/200810937실행파일의 아이콘을 프로그램 적으로 변경할 수 있을까요? [1]
753신동열3/12/200811333비스타의 권한 상승 관련 질문 있습니다. [2]
... 61  62  63  64  65  66  67  68  69  [70]  71  72  73  74  75  ...