0

我正在使用 Windows API ( 和 ) 中的一些注册表函数RegOpenKeyEx假设RegQueryInfoKeyRegEnumValue是我到目前为止的代码:

const int MAX_VALUE_NAME= 16383;
const int MAX_DATA = 16383;

DWORD i;
    HKEY hKey = HKEY_CURRENT_USER;
    LPCTSTR lpSubKey = TEXT("Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\RunMRU");
    DWORD ulOptions = 0;
    REGSAM samDesired = KEY_READ | KEY_WRITE | KEY_QUERY_VALUE;
    HKEY phkResult;
    DWORD dwIndex = 0;
    TCHAR lpValueName[MAX_VALUE_NAME];
    LPCTSTR ValueMRU;
    BYTE *DataMRU;
    DWORD lpcchValueName = MAX_VALUE_NAME;
    BYTE lpData[MAX_DATA+2];
    DWORD cbData = sizeof(lpData);
    DWORD type;

    TCHAR lpClass[MAX_PATH] = TEXT("");
    DWORD lpcClass = MAX_PATH;
    LPDWORD lpReserved = NULL;
    DWORD lpcSubKeys = 0;
    DWORD lpcMaxSubKeyLen;
    DWORD lpcMaxClassLen;
    DWORD lpcValues;
    DWORD lpcMaxValueNameLen;
    DWORD lpcMaxValueLen;
    DWORD lpcbSecurityDescriptor;
    FILETIME lpfLastWriteTime;
    char *pMsg = NULL;
    long R;

long OpenK = RegOpenKeyEx(hKey, lpSubKey, ulOptions, samDesired, &phkResult);

if (OpenK == ERROR_SUCCESS)
    {
        long Query = RegQueryInfoKey(phkResult, lpClass, &lpcClass, lpReserved, &lpcSubKeys, &lpcMaxSubKeyLen,
            &lpcMaxClassLen, &lpcValues, &lpcMaxValueLen, &lpcMaxValueLen, &lpcbSecurityDescriptor, &lpfLastWriteTime);

        if (Query == ERROR_SUCCESS)
        {
            if (lpcValues)
            {

                cout << "Number of values in the subkey: " << lpcValues << endl;
                cout << "\nThe values are:: \n" << endl;

                //Show RunMRU values and content.

                for (i = 0; i < lpcValues; i++)
                {

                    lpcchValueName = MAX_VALUE_NAME;
                    //lpValueName[0] = '\0';    
                    lpValueName[MAX_VALUE_NAME];
                    //lpData[MAX_DATA + 2];
                    cbData = MAX_DATA;


                    R = RegEnumValue(phkResult, i, lpValueName, &lpcchValueName, NULL,
                        &type, lpData, &cbData);

                    int Quantity = strlen((const char *)lpData);




                    if (R != ERROR_NO_MORE_ITEMS)
                    {

                            cout << "\0" << lpValueName << ": " << lpData << endl;
                            cout << "Number of characters: " << Quantity << endl;
                            cout << "\n";



                    }
                    else
                    {
                        cout << "Error enumerating values. Code: " << R << endl;
                    }



                }


            } //EOIF.

这就是我得到的:

在此处输入图像描述

问题是:

  1. 如何从 lpData 中删除字符串末尾的“\1”?[已解决:见下文]

PD。lpData 获取值的内容,而不是值。

  1. 如何在不影响“for”以及其他值和内容的情况下避免显示 RunMRU 值?

编辑1:我可以通过将其添加到以下内容来解决“\ 1”问题FOR

int Quantity = strlen(lpData);
std::string original = lpData;
std::string result = original.substr(0, original.size() - 2);
std::string result = original.substr(0, Quantity - 2);

if (R != ERROR_NO_MORE_ITEMS)
{
cout << "\0" << lpValueName << ": " << (TCHAR*)result.c_str() << endl; 
cout << "Numbers of characters: " << Quantity-2 << endl;
cout << "\n";

}
else 
{
cout << "Error enumerating the values. Code: " << R << endl;
}

现在我只需要知道如何避免在 FOR 中显示 MRUList 值。

4

2 回答 2

0
char* dest = new char[strlen(lpData) - 2];
memcpy(dest, lpData, strlen(lpData) - 2)

//do stuff with dest..
delete[] dest;

另一种方法是 std::string 它..

std::string dest = std::string(lpData);
dest.erase(std::find_last_of("\\1"), 2);
于 2013-10-13T15:07:04.493 回答
0

我想你可能不仅有\1\2甚至有可能\100,所以我的回答显示了如何从最后切掉所有这些东西。

您需要对您的价值进行子串化。尝试这个:

size_t len = strlen(lpData);
for (int i = len - i; i <= 0; --i)
{
    if (lpData == '\\')
    {
        lpData[i] = '\0';
        break;
    }
}

您可能需要一些其他程序而不是strlen取决于设置,您可以从这里选择它。大概wcslen


如何在不影响“for”以及其他值和内容的情况下避免显示 RunMRU 值?

这是更多的C解决方案,C++但这种方式性能更好。纯C++解决方案将连接std::string并需要更多时钟才能获得想要的结果。


您也可能会发现很有帮助。

于 2013-10-13T15:07:34.367 回答