File locked by which process?
Asked Answered
S

3

10

Is there a way in .Net to find out exactly which process has locked a file?

EDIT: I'm doing this because I want to let my user know that they can't modify/open the file, because at the moment, another program they're using (such as Excel) has it open. Hopefully, this helps.

Scouting answered 19/3, 2010 at 18:35 Comment(7)
The information would be useless, because by the time you do something with it, it could no longer be accurate.Fully
Really Josh? You sure about that...Hirundine
@SpaceghostAli Files are always locked indefinitely, no?Fully
Related: #1804Fully
@Josh Stodola The information would not be useless, I gave this question +1 because I have a use case in a production system where this info would be very handyHirundine
It's very useful in some circumstances. My users loved the "This drawing is locked by <username>" message I put in.Gutenberg
@SpaceghostAli OK, I see, I can appreciate that the user might find this information useful. But the bottom line is that programmatically tapping into to such information is never going to be 100% precise. So, I guess it's up to you to decide if you want to occasionally misinform your users.Fully
G
6

The short answer to this is no.

However, the long answer is that there are various API calls and WMI methods that you can use to find this information out, but don't expect it to be quick and simple.

If you want to use API calls, take a look at the NtQuerySystemInformation function with the SYSTEM_PROCESS_INFORMATION parameter. This is one of those lovely "undocumented" methods that comes with the wonderful disclaimer:

NtQuerySystemInformation may be altered or unavailable in future versions of Windows. Applications should use the alternate functions listed in this topic.

So I would suggest avoiding that in favour of using WMI.

You can use the WMI Win32_Process class to enumerate all processes currently running on the machine, and then enumerate all handles each process is holding until you find the file you are looking for. Unfortunatly there is no simple way to go "hey, which process is locking this file", it only works the other way round you have to search down the process list until you find the one that is locking the file you are interested in.

I'd recommend a nice little article on CodeProject titled How To: (Almost) Everything In WMI via C# Part 2: Processes. (Part 1 is also a good read if you like that kind of thing)

Gimpel answered 19/3, 2010 at 19:1 Comment(0)
N
1

Well... it's not exactly a .NET way of doing it... but assuming you just want to find out using an easy utility, check out Handle from SysInternals.

Nathalienathan answered 19/3, 2010 at 18:51 Comment(2)
I think Irwin is asking how to do it programmacitally, I don't think this really helps him with that.Gimpel
@Simon Well, technically, he could trap the exception and then programmatically invoke this command line tool to get the process(es) currently using the file. Far from ideal, yes, but possible!Fully
A
0

Looks like somebody has figured this one out (and you may learn some French as well :) )

http://www.axcis.com.au/bb/viewtopic.php?p=505

Audit answered 19/3, 2010 at 18:47 Comment(3)
That's active files by process. He's looking for vice versa.Fully
True - if it's not performance critical, you can enum the output of all processes looking for the file.Audit
When I implemented something like this for a Novell server I had to do it backwards like that--search everything looking for the file.Gutenberg

© 2022 - 2024 — McMap. All rights reserved.