Microsoft MVP성태의 닷넷 이야기
[답변]: ActiveX 브로커 모듈과 통신방법은 RPC ?? [링크 복사], [링크+제목 복사],
조회: 11258
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
부모글 보이기/감추기


IE 7 비스타 버전의 iexplore.exe 는 (보호 모드인 경우) 기본적으로 "low" 신뢰도 등급을 가진 상태의 프로세스로 시작되지요. 이전의 토픽에서 설명드렸지만, 일단 프로세스 시작시에 가졌던 신뢰도 등급은 실행중에 절대로 바뀌지 않습니다. 바로 여기에서 어려움이 시작됩니다.

그렇기 때문에, 보호 모드(low 신뢰도 등급)으로 실행되었던 IE 에서, 해당 신뢰도를 넘어서는 권한의 동작을 하고 싶다면 코드를 별도의 신뢰도 등급으로 실행되는 프로세스를 띄우고 거기에서 실행시켜야 합니다.

우선, IE 스스로는 이에 대해서 ieuser.exe 등급으로 설정된 프로세스를 이용해서 신뢰하는 사이트에 대해서 iexplore.exe 를 medium 등급으로 올려서 실행해주고 있으며, low / medium 동일하게 관리자 권한의 필요한 ActiveX 설치 작업이 필요한 경우에는 별도의 ieinstal.exe 를 구동시켜서 대신하고 있습니다.

그렇다면,,, 우리는?
이를 위해 마이크로소프트는 2가지 방식을 제안하고 있는데요.

하나는 관리 권한을 필요로 한다는 manifest 를 가진 사용자 정의 exe 프로세스를 실행시키는 방법과, 또 하나는 마이크로소프트에서 제공하는 별도의 delegate 프로세스를 사용하는 방법이 있습니다. (물론, 2가지 모두 이 한계를 넘기 위해 UAC 창을 통해서 사용자의 동의를 구합니다.)

두 가지 방법 모두, 별도의 프로세스에서 코드가 실행되는 것이므로 iexplore.exe 내의 코드에서 별도의 프로세스와 통신을 RPC (Remote Procedure Call) 를 통해서 해야 합니다. 사실 해당 문서에서 RPC 라고 언급을 하긴 했는데, 단순히 socket 을 열어서 통신을 해도 상관은 없습니다. (단지, RPC 라고 했으니 명시적으로 DCOM 관련 - 즉 local exe COM 개체 유형으로 다루는 것을 말하고 있는듯 합니다.)

RPC에 대해서 궁금하다고 하셨는데, ATL 프로젝트를 하나 생성하면 같이 딸려나오는 "PS" 프로젝트에서 마샬링을 위한 RPC 관련 코드를 볼 수 있습니다. 보시면 아시겠지만, 직접 RPC 함수를 이용해서 구현하는 것은 그다지 추천할 수는 없고 - 사실, 저 역시 한번도 해본적이 없습니다. - 차라리 local exe COM 개체를 고려하시는 것이 더 좋은 선택일 수 있습니다.

그 외에, 잘 알려진 CoCreateInstanceAsAdmin 함수를 이용하는 경우 "Allow merging of proxy/stub code"를 체크하도록 하고 있지만, (테스트는 해보지 않았지만 이론상으로) 제 생각에는 proxy/stub DLL 만 같이 등록되면 문제없이 동작할 것입니다. 아니면 (이것도 테스트는 안해봤지만.) universal marshaller 가 모든 것을 해줄 수 있도록 OLE Automation 을 따르는 것도 방법일테고.

---------

프로그램 런처를 만들고 싶다고 하셨는데. "함수" 호출과 같은 방식으로 exe 모듈과 통신할 일이 없다면 RPC 는 생각하지 마시고, 그냥 socket 이나 EXE 의 리턴값으로 결과를 받는 것만으로도 가능하지 않을까 싶군요.




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







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


비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
728정성태11/3/20079998    답변글 [답변]: 시스템 설계에 대한 문의드립니다. [2]
726한귀순10/24/200710702SQL 2005 Express 사용시.. [3]
725이방은10/23/200710678성태님 GDI+질문있어요.. [2]
724clic...10/17/200711933clickonce 작동시 무반응입니다. [1]
722한귀순10/11/200715617Internet Explorer 7.0 에서 ClickOnce Error [3]
721이카루스10/5/200711681WCF 질문드립니다.
723정성태10/14/20079989    답변글 [답변]: WCF 질문드립니다.
720limj...10/5/200711459인증서/스마트 카드에 기반한 Managed Card - STS 구현 질문 [2]
718DJ.처리10/2/200719890[VS.NET 2008] 스마트클라이언트 게시 오류...도와주세요~ [2]파일 다운로드2
716guest9/28/200715049실행시간이 긴 com+ 객체가 죽는거 같습니다. 어떻게 해야 할지.... [3]
713하민규9/19/200710413VC++ 6과 Vista UAC ..파일 다운로드1
715정성태9/28/200711289    답변글 [답변]: VC++ 6과 Vista UAC ..
711술푼어둠이9/17/200710376사설 IP 사용 문제?? [1]파일 다운로드1
709한귀순9/14/200710155asp.net 에서의 paging 관련. [2]
708이준영9/13/200712175마우스 커서의 움직이는 속도 알아내는 좋은 방법은?
712정성태9/17/200710643    답변글 [답변]: 마우스 커서의 움직이는 속도 알아내는 좋은 방법은?
707hatu...9/10/200710661window2000과 ssl 그리고 frame [2]
701소쿠리9/5/200710778Get 으로 넘긴 한글 문자열 Respose.AddHeader 에서 filename 으로 사용시 깨짐. [1]
699유현기9/3/200710720[질문1]스마트 클라이언트에서 웹의 변수를 스마트 클라이언트에서 받아쓰기(제발도와주세요 ㅠ.ㅠ)파일 다운로드1
700정성태9/3/20079930    답변글 [답변]: [질문1]스마트 클라이언트에서 웹의 변수를 스마트 클라이언트에서 받아쓰기(제발도와주세요 ㅠ.ㅠ)
696clev...8/31/200710221Exe COM으로 만들면 혹시 Bridge dll없이도 권한 상승이 가능한가요? [1]
702clev...9/5/20079863    답변글 [답변]: Exe COM으로 만들면 혹시 Bridge dll없이도 권한 상승이 가능한가요?
695스마일8/30/200710071Visaul Studio 2005에서 디버깅이 안되요...ㅠㅠ [1]
694이호정8/29/200710044[CardSpace 관련 질문] 정리해 좋으신 글 잘 보았습니다.
698정성태9/1/200710032    답변글 [답변]: [CardSpace 관련 질문] 정리해 좋으신 글 잘 보았습니다.
704이호정9/6/200710564        답변글 답변해주신 내용 잘 봤습니다. ^_^b
... 61  62  63  64  65  66  67  68  69  70  71  [72]  73  74  75  ...