The useful App Paths registry key : HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths
how to load BPLs without writing them in the system directory or in the application directory.
I suggested to use the "App paths" registry key
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths],
but while looking for a reference for its proper use I didn't find a complete one, even on MSDN.
It looks to be poorly documented, yet it's a very useful key.
First, you have to create a key under the App Paths key named after you application executable.
Then you have the following options:
- If you set the "default" value (which can be created passing an empty string as its name) to your application path and filename,
Windows will be able to run it just typing the exe name in the "Run" dialog or "Address" toolbar
(if you use it and ever wondered why it worked for some apps but not others, you know why now). - You can create a value (string type) named "Path",
which should contain a comma delimited list of directories where application DLLs can be found. - You can map an executable to another (look at the pbrush.exe entry, that maps it to mspaint.exe).
Some Microsoft applications (i.e. Office 2007) uses other values,
for example useURL (set to 1), but I have no clue if they are application specific values stored there, or have a broader meaning.
我们知道,在Windows中,单击“开始→运行”命令后,就可以在打开的对话框中输入相应的命令来打开一些系统工具,
如输入“regedit”后回车可以启动注册表编辑器,输入“notepad”后回车会启动记事本程序等等。
不过,在默认情况下,Windows只能支持少数的程序使用这样的便捷功能,
有没有什么办法可以让更多的程序享受这样的便捷启动呢?
当然有:我们只要在注册表中添加一些简单的信息,告诉Windows该怎样做就可以了!
打开注册表编辑器,依次展开
[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths]
分支,在“App Paths”主键下面我们可以看到很多名称为“xxxxx.exe”的次级主键,
点击某个主键可以在右边看见它的字符串,其中“Path”字符串为该程序的路径。
正是因为有了这些主键,我们可以在“运行”对话框中便捷地启动某一程序。
知道了这个原理,我们便可以自由地为其他程序添加便捷启动方式。
以QQ为例:我们要为QQ添加一个便捷启动方式,其安装路径为
D:\Program Files\Tencent\QQ.exe。
在“App Paths”下新建一个名为“QQ.exe”的子键(不能和已有名称重复),
然后在右侧窗口中将“Path”字符串设置为“D:\Program Files\Tencent\QQ.exe”即可。
退出注册表编辑器,在“运行”对话框直接输入“QQ”并回车,就可以启动QQ了!
提示:其实,我们还可以为任意文件添加快捷方式,Windows会自动调用相应的程序来打开这个文件。
添加的方法和上述一样,在“Path”字符串中输入程序的启动路径即可。
需要注意的是,新添加的次级主键名称必须要有扩展名,如EXE、TXT等。
若您使用EXE扩展名,在“运行”对话框中只需要输入名称就可以了;
若使用其他扩展名,必须输入名称+扩展名才可以启动。
比如使用了“CCE.exe”的名称,在“运行”对话框只需输入“CCE”便可启动;
若使用“CCE.txt”则需要输入“CCE.txt”才可启动相应文件。
THE WINDOWS “APP PATHS” REGISTRY KEY
This was news to me. Basically, not every app has to be on your PATH to be launched via executable name only (from anywhere).
For example, on my x64 Windows 7 machine, WordPad is located at:
<C:\Program Files\Windows NT\Accessories\wordpad.exe>
This is *not* set in my PATH environment variable. But I can go to Start > Run, and type wordpad, and it launches.
Why does this work? Because of “App Paths”.
<HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths>
How the App Paths Registry Key Makes Windows Both Faster and Safer
Why can you start Mozilla Firefox by typing “firefox” in the Run dialog and press enter?
Firefox.exe is not located in any directory in the path.
The same with Outlook (type “outlook”), PowerShell (“powershell”), VMware Workstation (“vmware”) or Adobe Reader (“acrord32″).
This “magic application starting thingy” works because of a little-known Windows feature based on the “App Paths” registry key.
App Paths – Dissection
In your forays through the Windows registry you may have noticed a peculiar key,
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\App Paths,
that has subkeys named like executables. Here is what it looks like on my machine:
Notice that the HKLM App Paths key and its counterpart in HKCU are basically mapping tables
between executable names and their full paths.
The direct subkeys of App Paths store the executable names,
while each subkey’s default value stores the full path to that executable.
Notice also, that the key “firefox.exe” has a named value “Path” that stores the path to the program’s installation directory.
So what is this all about?
App Paths – Explanation
The App Paths key provides a mechanism that allows programmers to make their application startable
by name only without having to modify the system-wide path.
Why would they do that?
Vanity and overestimation of the importance of one’s own application.
But, hey, it sometimes does come in handy to be able to start programs without having to type the full path,
just hit Win+R instead and type the executable name.
Getting more technical, modifying the system path is not exactly best practice since it may slow down the system,
break other applications and even create security holes.
To provide an alternative, Microsoft added the App Paths functionality in XP.
Whenever a new process is to be started with the API functions ShellExecute or ShellExecuteEx,
and only a file name without a path is specified, Windows looks in the following places for the executable:
- The current working directory.
- The Windows directory.
- The Windows\System32 directory.
- The directories listed in the PATH environment variable.
- If there is a App Paths subkey with the name of the executable, the key’s default value is used as the program’s full path.
If the subkey also has a value named Path, the string stored in Path is added to the PATH environment variable, but only for the process to be started.
As mentioned, the App Paths key has a second use, namely proving per-process PATH configurations,
reducing the need of application developers to modify the global system PATH.