Winapi 如何检查注册表中是否存在给定路径?

Winapi 如何检查注册表中是否存在给定路径?,winapi,mfc,Winapi,Mfc,实际上我有Path=Software\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Run,和Software\\Microsoft\\Windows\\CurrentVersion\\Run,我将根键作为HKEY\U USESRS传递,我从中获取子键。然后我将子键+路径合并…在循环中,我获取HKEY\U USERS\S-1-5-19\Software\Wow6432Node\Microsoft\Windows\CurrentVersion\

实际上我有Path=
Software\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Run
,和
Software\\Microsoft\\Windows\\CurrentVersion\\Run
,我将根键作为
HKEY\U USESRS
传递,我从中获取子键。然后我将子键+路径合并…在循环中,我获取
HKEY\U USERS\S-1-5-19\Software\Wow6432Node\Microsoft\Windows\CurrentVersion\Run
,这实际上在注册表…是否有检查完整路径是否存在的功能

listData.RemoveAll();
        HKEY hrKey=HKEY_USERS,hKey; 
        if(hrKey==HKEY_USERS)
        {
            TCHAR    achKey[MAX_KEY_LENGTH];   // buffer for subkey name
            DWORD    cbName;                   // size of name string 
            TCHAR    achClass[MAX_PATH] = TEXT("");  // buffer for class name 
            DWORD    cchClassName = MAX_PATH;  // size of class string 
            DWORD    cSubKeys=0;               // number of subkeys 
            DWORD    cbMaxSubKey;              // longest subkey size 
            DWORD    cchMaxClass;              // longest class string 
            DWORD    cValues;              // number of values for key 
            DWORD    cchMaxValue;          // longest value name 
            DWORD    cbMaxValueData;       // longest value data 
            DWORD    cbSecurityDescriptor; // size of security descriptor 
            FILETIME ftLastWriteTime;      // last write time  
            DWORD i, retCode; 
            // Get the class name and the value count. 
        retCode = RegQueryInfoKey(hrKey,                    // key handle 
                             achClass,                // buffer for class name 
                            &cchClassName,           // size of class string 
                            NULL,                    // reserved 
                            &cSubKeys,               // number of subkeys 
                            &cbMaxSubKey,            // longest subkey size 
                            &cchMaxClass,            // longest class string 
                            &cValues,                // number of values for this key 
                            &cchMaxValue,            // longest value name 
                            &cbMaxValueData,         // longest value data 
                            &cbSecurityDescriptor,   // security descriptor 
                            &ftLastWriteTime);       // last write time 
            if (cSubKeys)
            {

                for (i=0; i<cSubKeys; i++) 
                { 
                    cbName = MAX_KEY_LENGTH;
                    retCode = RegEnumKeyEx(hrKey, i,achKey,&cbName,NULL,NULL,NULL,&ftLastWriteTime); 
                    if (retCode == ERROR_SUCCESS) 
                    {

                        CString subKey=achKey;
                        if(subKey!=_T(".DEFAULT")&&(subKey.Mid(subKey.ReverseFind('_')+1)!=_T("Classes")))
                        {                               
                            csRegistryPath=subKey+_T("\\")+csRegistryPath;
                            CLog::Log( csRegistryPath);
                        }
                    }
                }
            } 
listData.RemoveAll();
HKEY hrKey=HKEY_用户,HKEY;
if(hrKey==HKEY_用户)
{
TCHAR achKey[MAX_KEY_LENGTH];//子键名称的缓冲区
DWORD cbName;//名称字符串的大小
TCHAR achClass[MAX_PATH]=TEXT(“”;//类名的缓冲区
DWORD cchClassName=MAX_PATH;//类字符串的大小
DWORD cSubKeys=0;//子键数
DWORD cbMaxSubKey;//最长子键大小
DWORD cchMaxClass;//最长的类字符串
DWORD cValues;//键的值数
DWORD cchMaxValue;//最长值名称
DWORD cbMaxValueData;//最长值数据
DWORD cbSecurityDescriptor;//安全描述符的大小
FILETIME ftLastWriteTime;//上次写入时间
dwordi,retCode;
//获取类名和值计数。
retCode=RegQueryInfoKey(hrKey,//键句柄
achClass,//类名称的缓冲区
&cchClassName,//类字符串的大小
NULL,//保留
&cSubKeys,//子键数
&cbMaxSubKey,//最长子键大小
&cchMaxClass,//最长的类字符串
&cValues,//此键的值数
&cchMaxValue,//最长值名称
&cbMaxValueData,//最长值数据
&cbSecurityDescriptor,//安全描述符
&ftLastWriteTime);//上次写入时间
if(csubkey)
{

对于(i=0;i对于Win32 API解决方案,您可以使用
RegOpenKeyEx
来测试密钥是否存在

请注意,不能硬编码
Wow6432Node
。使用
键\u WOW64\u 32KEY
标志指定要在注册表的32位视图中查找

你会想通过的

STANDARD_RIGHTS_READ | KEY_WOW64_32KEY

对于
RegOpenKeyEx

samDesired
参数,我想我的问题不清楚,现在我编辑了,请再检查一遍并给我建议..我实际上没有询问您建议的答案,请更加努力。我已经解释了如何检查注册表中是否存在路径。如果您想问其他问题stion,你需要弄清楚你在问什么。你的问题编辑对我来说没有任何澄清。
RegOpenKeyEx
是检查特定密钥是否存在的方法。