Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

컴퓨터에 실행된 프로세스 중에 닷넷 응용 프로그램임을 알 수 있는 방법 - C#

이에 대해서는, 어려운 방법을 쓰려면 한없이 어려워지겠지만 간단하게 생각하면 그다지 어렵지 않습니다.

쉽게 생각해 볼까요? ^^ 현재 대표적으로 .NET 2.0과 .NET 4.0 유형이 있으니, 이들을 실행해보고 "Process Explorer" 같은 도구를 이용하여 공통적으로 올라오는 DLL 을 확인해 볼 수 있습니다.

결과는 다음과 같습니다.

.NET 4.0
  • mscoree.dll
  • mscoreei.dll
  • clr.dll
  • clrjit.dll
.NET 2.0
  • mscoree.dll
  • mscorjit.dll
  • mscorwks.dll

mscoree.dll 파일이 중복되는군요. 그런데, 테스트를 하다 보니 mscoree.dll까지만 올라오고 실제 닷넷 응용 프로그램으로서 동작을 하면 로드가 되는 mscorlib.dll이 없는 프로세스들이 있었습니다. 일례로, explorer.exe가 그런 경우입니다. 음... 조금 고민하다가 그냥 mscorlib.dll로 판단하기로 했습니다.

이런 판단 기준으로 다음과 같이 코드를 실행하면 .NET 응용 프로그램을 구별해 낼 수 있습니다.

HashSet<string> _netApp = new HashSet<string>();
List<string> netAppList = new List<string>();

_netApp.Add("mscorlib.dll");
_netApp.Add("mscorlib.ni.dll");

foreach (Process process in Process.GetProcesses())
{
    if (IsNetApplication(process) == true)
    {
        Console.WriteLine(".NET Application: " + process.ProcessName);
        netAppList.Add(process.ProcessName);
    }
}

private bool IsNetApplication(Process process)
{
    try
    {
        if (Process.GetCurrentProcess().ProcessName == process.ProcessName)
        {
            return false;
        }

        foreach (ProcessModule module in process.Modules)
        {
            string fileName = Path.GetFileName(module.FileName).ToLower();

            if (_netApp.Contains(fileName) == true)
            {
                return true;
            }
        }
    }
    catch (Win32Exception)
    {
    }

    return false;
}

그런데, 아쉬움이 하나 있더군요. 뭐냐 하면, 위의 코드를 실행하는 EXE 프로세스가 x64이면 열람되는 응용 프로그램도 x64만 되고 x86의 경우에도 마찬가지 현상이 있었습니다. 하나의 응용 프로그램에서 그냥 모든 목록을 구할 수는 없는 걸까요?

이 대목에서 ^^ 다음의 글을 생각해 냈다면 SYSNET 웹 사이트를 아주 잘 이용하시는 분이라고 자부하셔도 좋겠습니다. ^^

x86/x64로 구분된 코드를 포함하는 경우, 다중으로 어셈블리를 만들어야 할까요?
; https://www.sysnet.pe.kr/2/0/1207

위에서 설명한 방식을 이용해서 프로그램 구조를 확장하면 x86 및 x64 응용 프로그램 모두를 열람할 수 있습니다. 코드가 중복되니, (지면은 없지만) '지면 관계상' 생략하고 첨부 파일에 넣어두었으니 참고하십시오. ^^

참고로, 제 컴퓨터에서 첨부 파일을 빌드해서 출력한 결과는 다음과 같습니다.

[x64 .NET Application]
.NET Application: MOM

[x86 .NET Application]
.NET Application: vsaenv10
.NET Application: vsmsvr10
.NET Application: devenv
.NET Application: iisexpress
.NET Application: iisexpresstray

그리고, 해당 EXE 파일을 '관리자 권한'으로 실행하면 NT 서비스까지 모두 열람할 수 있습니다.

[x64 .NET Application]
.NET Application: SMSvcHost
.NET Application: MOM
.NET Application: MsDepSvc

[x86 .NET Application]
.NET Application: vsaenv10
.NET Application: vsmsvr10
.NET Application: devenv
.NET Application: iisexpress
.NET Application: iisexpresstray




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







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

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

비밀번호

댓글 작성자
 



2012-04-20 04시57분
[탑] 와우...이런것도 있네요..
좋은 내용 감사합니다.
[guest]

... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11819정성태2/20/201923479Windows: 158. 컴퓨터와 사용자의 SID(security identifier) 확인 방법
11818정성태2/20/201921547VS.NET IDE: 131. Visual Studio 2019 Preview의 닷넷 프로젝트 빌드가 20초 이상 걸리는 경우 [2]
11817정성태2/17/201917463오류 유형: 514. WinDbg Preview 실행 오류 - Error : DbgX.dll : WindowsDebugger.WindowsDebuggerException: Could not load dbgeng.dll
11816정성태2/17/201921382Windows: 157. 윈도우 스토어 앱(Microsoft Store App)을 명령행에서 직접 실행하는 방법
11815정성태2/14/201919516오류 유형: 513. Visual Studio 2019 - VSIX 설치 시 "The extension cannot be installed to this product due to prerequisites that cannot be resolved." 오류 발생
11814정성태2/12/201918175오류 유형: 512. VM(가상 머신)의 NT 서비스들이 자동 시작되지 않는 문제
11813정성태2/12/201919168.NET Framework: 809. C# - ("Save File Dialog" 등의) 대화 창에 확장 속성을 보이는 방법
11812정성태2/11/201916531오류 유형: 511. Windows Server 2003 VM 부팅 후 로그인 시점에 0xC0000005 BSOD 발생
11811정성태2/11/201922377오류 유형: 510. 서버 운영체제에 NVIDIA GeForce Experience 실행 시 wlanapi.dll 누락 문제
11810정성태2/11/201919334.NET Framework: 808. .NET Profiler - GAC 모듈에서 GAC 비-등록 모듈을 참조하는 경우의 문제
11809정성태2/11/201922199.NET Framework: 807. ClrMD를 이용해 메모리 덤프 파일로부터 특정 인스턴스를 참조하고 있는 소유자 확인
11808정성태2/8/201923661디버깅 기술: 123. windbg - 닷넷 응용 프로그램의 메모리 누수 분석
11807정성태1/29/201921404Windows: 156. 가상 디스크의 용량을 복구 파티션으로 인해 늘리지 못하는 경우 [4]
11806정성태1/29/201920489디버깅 기술: 122. windbg - 덤프 파일로부터 PID와 환경 변수 등의 정보를 구하는 방법
11805정성태1/28/201923271.NET Framework: 806. C# - int []와 object []의 차이로 이해하는 제네릭의 필요성 [4]파일 다운로드1
11804정성태1/24/201920834Windows: 155. diskpart - remove letter 이후 재부팅 시 다시 드라이브 문자가 할당되는 경우
11803정성태1/10/201919807디버깅 기술: 121. windbg - 닷넷 Finalizer 스레드가 멈춰있는 현상
11802정성태1/7/201921438.NET Framework: 805. 두 개의 윈도우를 각각 실행하는 방법(Windows Forms, WPF)파일 다운로드1
11801정성태1/1/201922413개발 환경 구성: 427. Netsh의 네트워크 모니터링 기능 [3]
11800정성태12/28/201821806오류 유형: 509. WCF 호출 오류 메시지 - System.ServiceModel.CommunicationException: Internal Server Error
11799정성태12/19/201823751.NET Framework: 804. WPF(또는 WinForm)에서 UWP UI 구성 요소 사용하는 방법 [3]파일 다운로드1
11798정성태12/19/201822345개발 환경 구성: 426. vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++"
11797정성태12/19/201818072개발 환경 구성: 425. vcpkg - CMake Error: Problem with archive_write_header(): Can't create '' 빌드 오류
11796정성태12/19/201818903개발 환경 구성: 424. vcpkg - "File does not have expected hash" 오류를 무시하는 방법
11795정성태12/19/201822328Windows: 154. PowerShell - Zone 별로 DNS 레코드 유형 정보 조회 [1]
11794정성태12/16/201818233오류 유형: 508. Get-AzureWebsite : Request to a downlevel service failed.
... 76  77  78  79  80  81  82  83  84  85  [86]  87  88  89  90  ...