How to check if a program is using .NET?
Solution 1
There's a trick I once learned from Scott Hanselman's list of interview questions. You can easily list all programs running .NET in command prompt by using:
tasklist /m "mscor*"
It will list all processes that have mscor*
amongst their loaded modules.
We can apply the same method in code:
public static bool IsDotNetProcess(this Process process)
{
var modules = process.Modules.Cast<ProcessModule>().Where(
m => m.ModuleName.StartsWith("mscor", StringComparison.InvariantCultureIgnoreCase));
return modules.Any();
}
Solution 2
Use the CLR COM interfaces ICorPublish and ICorPublishProcess. The easiest way to do this from C# is to borrow some code from SharpDevelop's debugger, and do the following:
ICorPublish publish = new ICorPublish();
ICorPublishProcess process;
process = publish.GetProcess(PidToCheck);
if (process == null || !process.IsManaged)
{
// Not managed.
}
else
{
// Managed.
}
Solution 3
Use System.Reflection.Assembly.LoadFrom
function to load the .exe file. This function will throw exception if you try to load binary file that is not .NET assembly.
Solution 4
I know this is about a million years too late, but in case it helps - my favourite method to figure out if an exe is using .net is to run MSIL disassembler against it which comes with .net SDK. If a .net exe you indeed have, you'll get a nice graphical breakdown of its contents; if a plain old win32 exe it be, you'll get a message telling you so.
Solution 5
Programmatically you'd get the starting image name using Win32 API like NtQueryInformationProcess
, or in .Net use System.Diagnostics.Process.GetProcesses()
and read Process.StartInfo.FileName
.
Then open and decode the PE headers of that image using details prescribed in the MSDN article below:
http://msdn.microsoft.com/en-us/magazine/cc301808.aspx
Caveats: will only detect .NET built assemblies e.g. won't detect Win32 EXEs dynamically hosting CLR using CorHost APIs.
Comments
-
cpx almost 2 years
Can we check if a running application or a program uses .Net framework to execute itself?
-
lubos hasko over 14 yearswhat difference does it make? running application doesn't have .exe file?
-
John Saunders over 14 yearsIn that case, please show him how to find the EXE file corresponding to the running program; and show him how to deal with the possibility his process can't get read access to the .EXE file.
-
lubos hasko over 14 yearsYes, you are right, my answer is not complete and bulletproof and I'm sorry for sarcastic comment.
-
Dykam over 14 yearsNote this does leave out possible Mono processes.
-
ShockwaveNN over 14 years@Dykam Isn't mono's runtime also called mscorlib.dll ?
-
Dykam over 14 yearsThe runtime is just
mono
. Ormono.exe
on windows. .Net uses PE to let the OS use mscorlib.dll to start the app, but mono doesn't do such a trick. And the real core lib is called corlib.dll I think, as it isn't MS's corlib. -
user1703401 over 14 yearsI don't think this will work anymore for .NET 4.0, the DLLs were renamed. You'll also get false positives for apps that host the CLR, Visual Studio for example.
-
Brian Rasmussen over 14 yearsThe .NET 4.0 runtime is called clr.dll.
-
Mohib Sheth about 12 yearsI tried this, though the process was displayed in the list, IL Disassembler says its not a valid .net assembly.
-
Drakarah almost 12 yearsThis doesn't work if the hosting process is x64 and the exe is x86 only.
-
Neil Schaper almost 10 yearsGood answer. Specifically, run ILDASM.EXE, which is automatically installed with Visual Studio. See: msdn.microsoft.com/en-us/library/f7dy01k1(v=vs.110).aspx To launch ILDASM from Win8/VS2013: Start -> Visual Studio Tools --> Developer Command Prompt for VS2013. From Win8/VS2012: Start -> Developer Command -> Developer Command Prompt for VS2012. From Win7: All Programs -> Microsoft Visual Studio -> Visual Studio Tools -> Visual Studio Command Prompt.
-
stakx - no longer contributing over 7 yearsI was wondering, if you do this from C#, under which conditions will this check report "not managed"?
-
Eugene Podskal over 7 yearsIt seems that it will only consider managed those processes that have the same CLR used - social.msdn.microsoft.com/Forums/en-US/…. So one should be careful with it.
-
Matt over 4 yearsNice trick! But what is with .NET Core applications? I made some tests by myself converting a .net windows application into a .net core application, and the difference seems that .net core uses "System.Runtime.dll" (
tasklist /m "System.Runtime.dll"
), while .net uses "MSCOREE.DLL" (tasklist /m "mscor*"
). You can try it yourself:tasklist /M | find "YourAppName"
finds both versions of your application while they are running. -
Matt over 4 yearsAddition: To get both in one command line, I found you can use:
tasklist /FI "modules EQ MSCORE*" & tasklist /FI "modules EQ System.Runtime.dll"
- this will list the .NET applications first, then the .NET Core applications.