Microsoft MVP성태의 닷넷 이야기
글쓴 사람
조진우 (jwcho68 at hotmail.com)
홈페이지
첨부 파일
 

정성태님,

초면에 이렇게 도움을 청하게 되어 미안합니다. 하지만, 정성태님이 집필하신 C# 6.0을 보고 있는 늙은 독자이기도 합니다.
질문 내용은 집필하신 C# 6.0과 많이 관련이 없는 본인 실무에 관련된 것이라 좀 미안합니다.

다름이 아니라, 어떤 계측기에 Windows 8.1을 기본 OS로 하여 계측기 회사에서 제공하는 계측기 제어 프로그램이 있는데, 저희 고객이 계측기 회사에서 제공하는 기본 프로그램 대신에 고객의 입맞에 맞는 형태의 변형된 프로그램을 원하고 있습니다. 그래서, 좀 살펴 보았더니, COM 방식으로 많은 DLL 파일을 접근하여 다양한 측정 알고리즘을 DLL 파일에 심어 놓고 메인 프로그램이 필요할 때 마다 DLL파일의 Interface에 접근하여 독립적인 측정 기능을 수행하고, 그 결과를 다시 메인 프로그램으로 가져와 화면에 뿌려주는 것 같습니다.

문제는 메인 프로그램이 어떤 DLL을 어떤 시점에서 불러와 기능을 수행하게 하는지 모니터링할 수 있으면 너무 좋을 것 같은데 그 방법을 모르고 있습니다. 제가 가는 것이라곤 oleview.exe를 통해 많은 계측관련 알고리즘들이 고유한 CLSID를 가지고 있다는 것인데, 이것만으로는 고객이 원하는 프로그램을 작성할 수가 없어서 이렇게 도움을 청하게 되었습니다.

혹시, 실시간으로 메인 프로그램이 불려오는 DLL, CSLID, IID 등을 모니터링할 수 있는 방법이 있으면 알려 주시면 고맙겠습니다. 이와 같은 일을 수행하는데 조언이 있으시면 말씀에 주시면 고맙겠습니다.

초면에 질문드려 미안합니다.








[최초 등록일: ]
[최종 수정일: 2/1/2016]


비밀번호

댓글 작성자
 



2016-02-01 05시22분
일종의 리버스 엔지니어링으로 볼 수 있는데요. 응용 프로그램이 간단하다면 그런 식으로 접근하여 유추해볼 수 있지만 복잡도가 증가한다면 상당히 고된 작업일 수 있습니다.

이런 경우 가장 좋은 시나리오는, 해당 계측기 프로그램을 만든 회사에서 COM에 대한 매뉴얼을 공개하는 것입니다. 그렇다면 공식적으로 그에 따라 프로그램을 만들 수 있고 도움도 받을 수 있습니다.

그것이 어렵다면 어쩔 수 없습니다. DLL Injection과 함께 API 후킹 등을 통해서 알아내야합니다. 관련해서는 다음의 글이 도움이 될 수 있습니다.

Direct Show를 사용하는 다른 프로그램의 필터 그래프를 graphedt.exe에서 확인하는 방법
; http://www.sysnet.pe.kr/2/0/1652

원리만 알아두시고 후킹 관련해서는 공개된 라이브러리를 사용하는 것도 좋은 방법입니다.
정성태

1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5857guest3/17/20232990귀도 반 로썸을 보고 [4]
5856guest3/17/20233197Form1_FormClosing에 closing time을 Sqlite 저장하는 법? [6]파일 다운로드1
5855욜로3/17/20232777C# 메타데이터에서 불러오는 참조 정의가 안됨 [1]
5854민성3/16/20232967안녕하세요 asp.net mvc using문 관련하여 [1]
5853pa3/16/20233220오피스 2016 업데이트 후 파일 출력 불가 [1]
5852guest3/16/20232908입력 foreach 검색/출력 foreach [3]
5851guest3/15/20233244foreach내 list변경 [10]
5850독서가3/14/20232905C#에서 동적dll 사용시 문의입니다. [4]파일 다운로드1
5849guest3/9/20232894C# wpf로 Web에서 구동되는 hts가능한가요? (노트북없고 스마트폰 없음) [4]
5848민성3/9/20232802도움 요청드립니다. [2]파일 다운로드1
5847guest3/7/20232957SQlike Like 구문 - 1시간째 인데 안되네요 [13]
5846Huuu...3/7/20232641웹 다운로드에 대한 고찰 [5]파일 다운로드1
5845guest3/7/20232663C# Split함수의 불친절함 [1]
5844까망이3/7/20232781c# 무료 디컴파일러는 어떤게 좋습니까? [1]
5843guest3/7/20232747판매 후 dll 등 에러 [5]
5842kr13/6/20232789publish 할 때 분석기 관련 dll 제외 [5]
5841guest3/3/20232972프로그램 판매 시 - Upgrade 버전 판매 [2]
5840joe3/2/20233073C# 클래스 라이브러리 수정 -> C++에서 참조시 함수 목록 갱신되지 않음. [4]파일 다운로드1
5839guest3/2/20233704윈도우 서비스 프로그램 - FORM 애플리케이션 감시서비스 [8]
5838랄랄라3/1/20232909event 사용 시 두 표현의 차이점이 있을까요? [1]
5837감사합니...2/28/20233064오라클 DB서버 접속관련 문의 드립니다.(Load Balancing, HA Events) [2]
5836박지범2/27/20232856static instance의 initialize 순서가 보장되나요? [6]
5835주민호2/25/20235683Windows Software Development Kit - 최신버전 1개 남기고 다 삭제하면 안되는지요? [10]파일 다운로드1
5834guest2/24/20232909Python IDE - 비주얼스튜디오 [3]
5833무지남2/23/20232615Async 메서드 그리고 나서 Bool 메서드 [5]
5832김지우2/21/20232918event와 delegate의 차이 , event를 써야하는 이유 [1]
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...