Why do you see .exe.local files created on Windows?

In short, it’s a technique called Dynamic-Link Library (DLL) Redirection, where in to use DLL redirection, create a redirection file for your application. The redirection file must be named as follows: App_name.local.

For example, if the application name is Editor.exe, the redirection file should be named Editor.exe.local. You must install the .local file in the application directory. You must also install the DLLs in the application directory.

 

More details from MS article:

Applications can depend on a specific version of a shared DLL and start to fail if another application is installed with a newer or older version of the same DLL. There are two ways to ensure that your application uses the correct DLL: DLL redirection and side-by-side components. Developers and administrators should use DLL redirection for existing applications, because it does not require any changes to the application. If you are creating a new application or updating an application and want to isolate your application from potential problems, create a side-by-side component.

To use DLL redirection, create a redirection file for your application. The redirection file must be named as follows: App_name.local. For example, if the application name is Editor.exe, the redirection file should be named Editor.exe.local. You must install the .local file in the application directory. You must also install the DLLs in the application directory.

The contents of a redirection file are ignored, but its presence causes Windows to check the application directory first whenever it loads a DLL, regardless of the path specified to LoadLibrary or LoadLibraryEx. If the DLL is not found in the application directory, then these functions use their usual search order. For example, if the application c:myappmyapp.exe calls LoadLibrary using the following path:

c:program filescommon filessystemmydll.dll

And, if both c:myappmyapp.exe.local and c:myappmydll.dll exist, LoadLibrary loads c:myappmydll.dll. Otherwise, LoadLibrary loads c:program filescommon filessystemmydll.dll.

Alternatively, if a directory named c:myappmyapp.exe.local exists and contains mydll.dll, LoadLibrary loads c:myappmyapp.exe.localmydll.dll.

Known DLLs cannot be redirected. For a list of known DLLs, see the following registry key: HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlSession ManagerKnownDLLs. The system uses Windows File Protection to ensure that system DLLs such as these are not updated or deleted except by operating system updates such as service packs.

Windows 2000:  Known DLLs can be redirected.

If the application has a manifest, then any .local files are ignored.

Windows 2000:  Manifests do not affect DLL redirection.

If you are using DLL redirection and the application does not have access to all drives and directories in the search order, LoadLibrary stops searching as soon as access is denied. (If you are not using DLL redirection, LoadLibrary skips directories that it cannot access and then continues searching.)

It is good practice to install application DLLs in the same directory that contains the application, even if you are not using DLL redirection. This ensures that installing the application does not overwrite other copies of the DLL and cause other applications to fail. Also, if you follow this good practice, other applications do not overwrite your copy of the DLL and cause your application to fail.

 

Other References: DotLocal (.local) Dll Redirection

Leave a Reply

Your email address will not be published. Required fields are marked *