C++訪(fǎng)問(wèn)注冊(cè)表獲取已安裝軟件信息列表示例代碼
// ---------------------------------------------------------------
// FlieNmae:
// SofInfo.h
// Remark:
// 通過(guò)讀取注冊(cè)表獲得本機(jī)已安裝軟件信息。
// ---------------------------------------------------------------
#pragma once
#include <vector>
struct SoftInfo
{
// 軟件名
CString m_strSoftName;
// 軟件版本號(hào)
CString m_strSoftVersion;
// 軟件安裝目錄
CString m_strInstallLocation;
// 軟件發(fā)布廠(chǎng)商
CString m_strPublisher;
// 主程序所在完整路徑
CString m_strMainProPath;
// 卸載exe所在完整路徑
CString m_strUninstallPth;
};
class CSoftInfo
{
private:
// 保存已安裝常用軟件安裝信息
std::vector<SoftInfo> m_SoftInfoArr;
// 保存系統(tǒng)補(bǔ)丁信息
std::vector<SoftInfo> m_SystemPatchesArr;
public:
CSoftInfo();
~CSoftInfo(){}
// 獲取一個(gè)包含常用軟件安裝信息的Vector
std::vector<SoftInfo> GetSoftInfo (void) const;
// 獲取所有已安裝常用軟件名
void GetSoftName (std::vector<LPCTSTR>& lpszSoftName);
// 獲取所有已安裝常用軟件版本號(hào)
void GetSoftVersion (std::vector<LPCTSTR>& lpszSoftVersion);
// 獲取所有已安裝常用軟件安裝目錄
void GetInstallLocation (std::vector<LPCTSTR>& lpszInstallLocation);
// 獲取所有已安裝常用軟件發(fā)布廠(chǎng)商
void GetPublisher (std::vector<LPCTSTR>& lpszPublisher);
// 獲取所有已安裝常用軟件主程序所在路徑
void GetMainProPath (std::vector<LPCTSTR>& lpszMainProPath);
// 獲取所有已安裝常用軟件卸載程序所在路徑
void GetUninstallPth (std::vector<LPCTSTR>& lpszSoftName);
// 獲取一個(gè)包含系統(tǒng)補(bǔ)丁信息的Vector
std::vector<SoftInfo> GetSystemPatchesInfo (void) const;
// 獲取所有已安裝系統(tǒng)補(bǔ)丁名
void GetSystemPatchesName (std::vector<LPCTSTR>& lpszSoftName);
};
// FlieNmae: Softinfo.cpp
#include "stdafx.h"
#include "SoftInfo.h"
CSoftInfo::CSoftInfo()
{
struct SoftInfo softinfo;
HKEY RootKey; // 主鍵
LPCTSTR lpSubKey; // 子鍵名稱(chēng)
HKEY hkResult; // 將要打開(kāi)鍵的句柄
HKEY hkRKey;
LONG lReturn; // 記錄讀取注冊(cè)表是否成功
CString strBuffer;
CString strMidReg;
DWORD index = 0;
TCHAR szKeyName[255] = {0}; // 注冊(cè)表項(xiàng)名稱(chēng)
TCHAR szBuffer[255] = {0};
DWORD dwKeyLen = 255;
DWORD dwNameLen = 255;
DWORD dwType = REG_BINARY|REG_DWORD|REG_EXPAND_SZ|REG_MULTI_SZ|REG_NONE|REG_SZ;
RootKey = HKEY_LOCAL_MACHINE;
lpSubKey = _T("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall");
lReturn = RegOpenKeyEx(RootKey, lpSubKey, 0, KEY_ALL_ACCESS, &hkResult);
if (lReturn == ERROR_SUCCESS)
{
while (ERROR_NO_MORE_ITEMS !=RegEnumKeyEx(hkResult, index, szKeyName, &dwKeyLen, 0, NULL, NULL, NULL))
{
index++;
strBuffer.Format(_T("%s"), szKeyName);
if (!strBuffer.IsEmpty())
{
strMidReg = (CString)lpSubKey +_T("\\") + strBuffer;
if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, strMidReg, 0, KEY_ALL_ACCESS, &hkRKey)==ERROR_SUCCESS)
{
RegQueryValueEx(hkRKey, _T("DisplayName"), 0, &dwType, (LPBYTE)szBuffer,&dwNameLen);
softinfo.m_strSoftName = szBuffer;
dwNameLen = 255;
memset(szBuffer, 0, 255);
RegQueryValueEx(hkRKey, _T("DisplayVersion"), 0, &dwType, (LPBYTE)szBuffer,&dwNameLen);
softinfo.m_strSoftVersion = szBuffer;
dwNameLen = 255;
memset(szBuffer, 0, 255);
RegQueryValueEx(hkRKey, _T("InstallLocation"), 0, &dwType, (LPBYTE)szBuffer,&dwNameLen);
softinfo.m_strInstallLocation = szBuffer;
dwNameLen = 255;
memset(szBuffer, 0, 255);
RegQueryValueEx(hkRKey, _T("Publisher"), 0, &dwType, (LPBYTE)szBuffer,&dwNameLen);
softinfo.m_strPublisher = szBuffer;
dwNameLen = 255;
RegQueryValueEx(hkRKey, _T("InstallLocation"), 0, &dwType, (LPBYTE)szBuffer,&dwNameLen);
softinfo.m_strMainProPath = szBuffer;
dwNameLen = 255;
memset(szBuffer, 0, 255);
RegQueryValueEx(hkRKey, _T("UninstallString"), 0, &dwType, (LPBYTE)szBuffer,&dwNameLen);
softinfo.m_strUninstallPth = szBuffer;
dwNameLen = 255;
memset(szBuffer, 0, 255);
if(!softinfo.m_strSoftName.IsEmpty())
{
if(strBuffer.GetAt(0) == 'K' && strBuffer.GetAt(1) == 'B')
{
m_SystemPatchesArr.push_back(softinfo);
}
else
{
m_SoftInfoArr.push_back(softinfo);
}
}
}
dwKeyLen = 255;
memset(szKeyName,0, 255);
}
}
RegCloseKey(hkResult);
}
else
{
::MessageBox(NULL, _T("打開(kāi)注冊(cè)表失敗!"), NULL, MB_ICONWARNING);
}
}
std::vector<SoftInfo> CSoftInfo::GetSoftInfo (void) const
{
return m_SoftInfoArr;
}
void CSoftInfo::GetSoftName (std::vector<LPCTSTR>& lpszSoftName)
{
std::vector<SoftInfo>::iterator iter;
for (iter = m_SoftInfoArr.begin(); iter != m_SoftInfoArr.end(); iter++)
{
lpszSoftName.push_back(iter->m_strSoftName);
}
}
void CSoftInfo::GetSoftVersion (std::vector<LPCTSTR>& lpszSoftVersion)
{
std::vector<SoftInfo>::iterator iter;
for (iter = m_SoftInfoArr.begin(); iter != m_SoftInfoArr.end(); iter++)
{
if (!(iter->m_strSoftVersion).IsEmpty())
{
lpszSoftVersion.push_back(iter->m_strSoftVersion);
}
}
}
void CSoftInfo::GetInstallLocation (std::vector<LPCTSTR>& lpszInstallLocation)
{
std::vector<SoftInfo>::iterator iter;
for (iter = m_SoftInfoArr.begin(); iter != m_SoftInfoArr.end(); iter++)
{
if (!(iter->m_strInstallLocation).IsEmpty())
{
lpszInstallLocation.push_back(iter->m_strInstallLocation);
}
}
}
void CSoftInfo::GetPublisher (std::vector<LPCTSTR>& lpszPublisher)
{
std::vector<SoftInfo>::iterator iter;
bool bSign;
for (iter = m_SoftInfoArr.begin(); iter != m_SoftInfoArr.end(); iter++)
{
bSign = true;
// 初步去重復(fù)廠(chǎng)商
std::vector<LPCTSTR>::iterator itr;
for (itr = lpszPublisher.begin(); itr != lpszPublisher.end(); itr++)
{
if (iter->m_strPublisher == (CString)*itr)
{
bSign = false;
}
}
if (bSign)
{
lpszPublisher.push_back(iter->m_strPublisher);
}
}
}
void CSoftInfo::GetMainProPath (std::vector<LPCTSTR>& lpszMainProPath)
{
std::vector<SoftInfo>::iterator iter;
for (iter = m_SoftInfoArr.begin(); iter != m_SoftInfoArr.end(); iter++)
{
if (!(iter->m_strMainProPath).IsEmpty())
{
lpszMainProPath.push_back(iter->m_strMainProPath);
}
}
}
void CSoftInfo::GetUninstallPth (std::vector<LPCTSTR>& lpszSoftName)
{
std::vector<SoftInfo>::iterator iter;
for (iter = m_SoftInfoArr.begin(); iter != m_SoftInfoArr.end(); iter++)
{
if (!(iter->m_strUninstallPth).IsEmpty())
{
lpszSoftName.push_back(iter->m_strUninstallPth);
}
}
}
std::vector<SoftInfo> CSoftInfo::GetSystemPatchesInfo (void) const
{
return m_SystemPatchesArr;
}
void CSoftInfo::GetSystemPatchesName (std::vector<LPCTSTR>& lpszSoftName)
{
std::vector<SoftInfo>::iterator iter;
for (iter = m_SystemPatchesArr.begin(); iter != m_SystemPatchesArr.end(); iter++)
{
lpszSoftName.push_back(iter->m_strSoftName);
}
}
相關(guān)文章
基于Qt實(shí)現(xiàn)簡(jiǎn)易GIF播放器的示例代碼
這篇文章主要介紹了如何利用Qt設(shè)計(jì)一個(gè)簡(jiǎn)易GIF播放器,可以播放GIF動(dòng)畫(huà)。其基本功能有載入文件、播放、暫停、停止、快進(jìn)和快退,感興趣的可以了解一下2022-06-06c++實(shí)現(xiàn)MD5算法實(shí)現(xiàn)代碼
用c++實(shí)現(xiàn)了md5算法。包含 md5.h 和md5.cpp 兩個(gè)文件。主要參考百度百科 “MD5” 原理,代碼中變量命名也是參考其中的公式,程序的使用說(shuō)明在md5.h 文件的末尾注釋中2013-11-11帶你了解C++的動(dòng)態(tài)內(nèi)存分配
今天小編就為大家分享一篇關(guān)于關(guān)于C++動(dòng)態(tài)分配內(nèi)存的介紹,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2021-08-08c++實(shí)現(xiàn)一個(gè)簡(jiǎn)易的網(wǎng)絡(luò)緩沖區(qū)的實(shí)踐
這篇文章主要介紹了c++實(shí)現(xiàn)一個(gè)簡(jiǎn)易的網(wǎng)絡(luò)緩沖區(qū)的實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12Qt使用事件與定時(shí)器實(shí)現(xiàn)字幕滾動(dòng)效果
我們經(jīng)常能夠在外面看到那種滾動(dòng)字幕,那么本文就拿Qt來(lái)做一個(gè)吧,本文將使用事件與定時(shí)器實(shí)現(xiàn)字幕滾動(dòng)的效果,感興趣的小伙伴可以了解一下2023-06-06C語(yǔ)言中static的作用及C語(yǔ)言中使用靜態(tài)函數(shù)有何好處
在C語(yǔ)言中,static的作用有三條:一是隱藏功能,二是保持持久性功能,三是默認(rèn)初始化為0。本文重點(diǎn)給大家介紹C語(yǔ)言中static的作用及c語(yǔ)言中使用靜態(tài)函數(shù)有何好處,對(duì)本文感興趣的朋友一起看看吧2015-11-11Qt定時(shí)器類(lèi)QTimer使用詳解與注意事項(xiàng)
Qt提供了兩種定時(shí)器,一種是QObject類(lèi)的定時(shí)器,另一種是QTimer類(lèi)的定時(shí)器,這篇文章主要給大家介紹了關(guān)于Qt定時(shí)器類(lèi)QTimer使用與注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2023-10-10