Recently while looking at the security tab on a file, I found there was a user that was an unknown account. It wasn’t registered with the Windows Vista System.
data:image/s3,"s3://crabby-images/72b2c/72b2c9a20c13d13c64259b5cad839abccc8e37ba" alt="accountunknown2 accountunknown2"
Looking around the system, I found several more files, so I decided to figure out where this account came from.
An internet search about Account SIDs turned up a page on Wikipedia about Security identifier. This box from the chart gave me the answer.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="DomainSIDnfo DomainSIDnfo"
I needed to find the SID of the system I found in the file, but how?
So back to the internet search again. First, I needed a way to easily get the information from the file, secondly, I needed to get the SID of the system. The answer to that was to build 2 new programs.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="GetAclNfo GetAclNfo"
In the screen shot above, you see that the known accounts return the name only but the unknown returns the SID only.
GetFileSecurityInfo
(above) and GetComputerSID
(below)
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="GetComputerSIDa GetComputerSIDa"
I have a dual boot system (Windows Vista Ultimate x64 (my main) and Windows 7 Ultimate x64) also 2 VHDs . Since I had only 4 systems to check, it was just a matter of checking computer SIDs till one matched.
The SID turned out to belong to Windows 7.
Now that we found the system where the SID comes from, that brings me to another 1 of 2 tools I built previously for getting the user SID of known users.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="UserAccountNfo4 UserAccountNfo4"
This one above called All User Account NFO or, the one below called User name Account Information.
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="UserAccountNfo5 UserAccountNfo5"
What we are looking for is to match the SID for the first section to the system SID, then the last 4 numbers will give us the user account on that system. These particular screen shots above are from the Vista VHD, which does not match the number in either section of the SID we are looking for. (See screen shot below to compare the numbers.)
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="getaclnfoCropNoted getaclnfoCropNoted"
The User turned out to be my account on Windows 7.
So how did it get on the system to start with?
While booted into the Windows 7 OS, I navigated to the partition for the Windows Vista and had to click a box to allow the Windows 7 access on that partition for the areas I needed to get access to. It is amazing how far the inheritance travels in a system.
Well, another mystery solved.
I have not tested if a deleted account on the same system would leave a Unknown Account on a file or not.
Reference
The code basis for the GetComputerSID.exe was found at an MSDN Forum where I added my code to the page after the person that originally listed it. I had to convert what they had to VB, then get it to work.
The code basis for the GetFileSecurityInfo.exe was found at EGGHEADCAFE.com.
To get the SID of the computer, you can also use a command line tool called PsGetSid located on the Windows Sysinternals web site.
Edit: Removed Lik to my website that I had to let go.
Remember to check your references and imports in VB to get the code to work.
Tagged: Account Unknown, security tab, User Account Tools, VB
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt="Image 15"