C++访问注册表获取已安装软件信息列表示例代码_C 语言

复制代码 代码如下:

// ---------------------------------------------------------------
// FlieNmae:
//   SofInfo.h
// Remark:
//   通过读取注册表获得本机已安装软件信息。
// ---------------------------------------------------------------
#pragma once
#include <vector>

struct SoftInfo
{
    // 软件名
    CString m_strSoftName;
    // 软件版本号
    CString m_strSoftVersion;
    // 软件安装目录
    CString m_strInstallLocation;
    // 软件发布厂商
    CString m_strPublisher;
    // 主程序所在完整路径
    CString m_strMainProPath;
    // 卸载exe所在完整路径
    CString m_strUninstallPth;
};

class CSoftInfo
{
private:
    // 保存已安装常用软件安装信息
    std::vector<SoftInfo> m_SoftInfoArr;
    // 保存系统补丁信息
    std::vector<SoftInfo> m_SystemPatchesArr;

public:
    CSoftInfo();
    ~CSoftInfo(){}

    // 获取一个包含常用软件安装信息的Vector
    std::vector<SoftInfo> GetSoftInfo (void) const;
    // 获取所有已安装常用软件名
    void GetSoftName (std::vector<LPCTSTR>& lpszSoftName);
    // 获取所有已安装常用软件版本号
    void GetSoftVersion (std::vector<LPCTSTR>& lpszSoftVersion);
    // 获取所有已安装常用软件安装目录
    void GetInstallLocation (std::vector<LPCTSTR>& lpszInstallLocation);
    // 获取所有已安装常用软件发布厂商
    void GetPublisher (std::vector<LPCTSTR>& lpszPublisher);
    // 获取所有已安装常用软件主程序所在路径
    void GetMainProPath (std::vector<LPCTSTR>& lpszMainProPath);
    // 获取所有已安装常用软件卸载程序所在路径
    void GetUninstallPth (std::vector<LPCTSTR>& lpszSoftName);

    // 获取一个包含系统补丁信息的Vector
    std::vector<SoftInfo> GetSystemPatchesInfo (void) const;
    // 获取所有已安装系统补丁名
    void GetSystemPatchesName (std::vector<LPCTSTR>& lpszSoftName);
};

复制代码 代码如下:

// FlieNmae: Softinfo.cpp

#include "stdafx.h"
#include "SoftInfo.h"

CSoftInfo::CSoftInfo()
{
    struct SoftInfo softinfo;
    HKEY RootKey;            // 主键
    LPCTSTR lpSubKey;        // 子键名称
    HKEY hkResult;            // 将要打开键的句柄
    HKEY hkRKey;
    LONG lReturn;            // 记录读取注册表是否成功
    CString strBuffer;
    CString strMidReg;

    DWORD index = 0;
    TCHAR szKeyName[255] = {0};        // 注册表项名称
    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("打开注册表失败!"), 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;

        // 初步去重复厂商
        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);
    }
}

时间: 2024-10-31 16:53:18

C++访问注册表获取已安装软件信息列表示例代码_C 语言的相关文章

VC读注册表获取安装程序

Windows 系统中,安装程序都可以在注册表 HKEY_LOCAL_MACHINE\SoftWare\Microsoft\Windows\CurrentVersion\Uninstall获取,并且xp.vista .win7.win8都一样 打开注册表命令:regedit,依次展开上述注册表路径,安装程序列表如下图: 获取系统安装程序列表: // 获取系统安装程序列表 BOOL CMyListCtrlTestDlg::AllRegKey(HKEY hKey, LPCTSTR szDesKeyI

使用 Visual Basic .NET 访问注册表

visual|访问|注册表 在 Visual Basic .NET 中编程时,可以选择通过 Visual Basic .NET 提供的函数或者 .NET 框架的注册表类来访问注册表.虽然多数情况下使用 Visual Basic 函数已经足够,但有时仍需要使用 .NET 框架. 注册表储存了有关操作系统的信息以及计算机上安装的应用程序的信息.使用注册表可能会影响安全性.因此,必须仔细检查访问注册表的代码以确保不会给将运行该代码的计算机带来安全影响. 注册表项包括两部分:值名称和值.项目存储在项和子

C# 系统应用之通过注册表获取USB使用记录(一)

该文章是"个人电脑历史记录清除软件"项目的系统应用系列文章.前面已经讲述了如何清除IE浏览器的历史记录.获取Windows最近访问文件记录.清除回收站等功能.现在我需要完成的是删除USB设备上的U盘.手机.移动硬盘等记录,真心觉得这方面资料特别少.这篇文章首先主要讲述了通过注册表获取USB使用记录,希望对大家有所帮助. 一.注册表基本知识 注册表(registry)是Windows系统中一个重要的数据库,它用于存储有关应用程序.用户和系统信息.注册表的结构就像一颗树.树的顶级节点(hi

c# 4 0-利用c#代码 访问注册表 不能向注册表里修改数据 求助

问题描述 利用c#代码 访问注册表 不能向注册表里修改数据 求助 我要实现的是通过对注册表的修改 实现隐藏和显示桌面图标 谢谢各位上面的代码就不写了 主要的是 try { int i = 1; RegistryKey key = Registry.CurrentUser; RegistryKey hide = key.OpenSubKey(@""SoftwareMicrosoftWindowsCurrentVersionExplorerAdvanced"" true

利用VB.NET访问注册表

访问|注册表 利用VB.NET访问注册表 译者注:访问注册表的例子比较多,然而通过VB.NET访问注册表的例子并不多,本文翻译了一篇MSDN上的利用VB.NET存取注册表的例子,挺详细也挺全面的. ( http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dv_vstechart/html/vbtchimpdragdrop.asp) Cat FrancisVisual Studio TeamMicrosoft Corpo

Delphi编程访问注册表

注册表是windows系统的一个庞大数据库,它存储着系统硬件.软件及用户信息.适当修改注册表的参数值,可以提高系统的性能.注册表的修改通常有两种途径:其一是利用windows系统提供的"RegEdit"命令进行修改.此种方法虽说直观,但由于注册表的复杂性,对于一般用户来说,此方法并不十分可行.其二就是以编程方式来访问注册表.掌握这种方法,对于程序员来说,是一个重要的基本技术.因为在我们的编程过程中,很多地方都需要以程序方式去访问注册表.比如大家熟悉的"超级兔子".&

用SetupAPI结合注册表获取USB优盘序列号

//---------------------------------------------------------------------------#include <setupapi.h>#include <stdio.h>#include <objbase.h>#ifndef __BORLANDC__#pragma comment(lib, "setupapi.lib")#endif//---------------------------

Win 8提示“注册表编辑已被管理员禁用”怎么办?

  解决办法: 1.右键[开始]图标,在弹出菜单中选择[运行],输入gpedit.msc,确定; 2.打开本地组策略编辑器,展开用户配置->管理模板->系统; 3.点击[系统],在右侧窗格,找到"阻止访问注册表编辑工具",右键点击"编辑"; 4.选择"未配置"或者"以禁用",点击确定. 以上就是对Win 8提示"注册表编辑已被管理员禁用"问题的解决方法的介绍,又同样问题的朋友可以尝试下,希望可以

NSIS:在注册表中记录安装路径以便重装或升级时读取

原文 NSIS:在注册表中记录安装路径以便重装或升级时读取 在NSIS中,这个功能是非常有用的,可以避免用户把程序安装到多个位置的尴尬. 第1步:在"安装目录选择页面"前面加入以下代码:  1 !define MUI_PAGE_CUSTOMFUNCTION_show Pageshow 第2步:读取注册表中关于安装路径的键值,如果没有,就使用默认路径. 1 InstallDirRegKey HKCU "Software\eBook Workshop" "&q