Microsoft MVP성태의 닷넷 이야기
WCF channel faulted 관련 [링크 복사], [링크+제목 복사]
조회: 13634
글쓴 사람
임동찬 (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로 그 값을 조회하는 것이 바람직할 것 같습니다.
정성태

... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1234(non...3/10/201414014(글쓴이의 요청으로 삭제합니다.) [3]
1233(non...3/9/201412131(글쓴이의 요청으로 삭제합니다.) [4]
1232(non...3/8/201411227(글쓴이의 요청으로 삭제합니다.) [2]
1231(non...3/7/201412518(글쓴이의 요청으로 삭제합니다.) [9]
1230POCO3/7/201412881쓰레드 안에서 DependencyProperty get, set시 또 다른 스레드 오류.. [1]
1229(non...3/6/201412580(글쓴이의 요청으로 삭제합니다.) [11]
1228POCO3/6/201411115안녕하세요. 질문이 있습니다. [1]
1226김형진3/4/201419682안녕하세요 windows azure에 관해 질문했던 사람입니다. [2]
1224(non...3/3/201415828(글쓴이의 요청으로 삭제합니다.) [11]
1223sadf...3/3/201411389아래 질문에 답변 감사드립니다. 한가지 더 궁금한점이 있어 질문드립니다. [1]
1222(non...3/2/201412242(글쓴이의 요청으로 삭제합니다.) [4]
1221(non...3/1/201412296(글쓴이의 요청으로 삭제합니다.) [2]
1220Until2/28/201410845질문드립니다. [1]
1219이성환2/28/201410521string.Join()과 Enumerable.Aggregate()의 차이가 궁금합니다. [2]파일 다운로드1
1218김형진2/25/201411969안녕하세요. window azure에 대해서 질문이 있어서 문의 드립니다 [4]
1217(non...2/23/201412408(글쓴이의 요청으로 삭제합니다.) [1]
1215아리수2/20/201415957C# 공부하면서 WPF에 대한 질문. [2]
1214조광훈2/20/201414188IIS8 응용프로그램 풀 관련 질문 드립니다. [2]파일 다운로드1
1213김태훈2/17/201411079가상화 프로그램 질문입니다. [1]파일 다운로드1
1212조광훈2/13/201410248ISAPI 필터에서 커스텀 헤더 정보 추가 [1]파일 다운로드1
1211조광훈2/12/201413663isapi 필터 로드 오류 [2]
1208박지호2/9/201417042[오타] 시작하세요 C# 프로그래밍 p.267 ~ 350 [1]
1207임동찬2/5/201411492Web페이지에서 .net application 실행시키는 방법 [3]
1206신지환2/3/201413362visual sourcesafe(internet) 체크인 에러 [1]
1205박지호2/2/201414898[오타] 시작하세요 C# 프로그래밍 p.199 ~ 202 [1]
1204김태훈1/27/201426373Windows Service 오류 문의입니다. [2]
... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...