数据类型

注册表的数据类型主要有以下四种:
显示类型(在编辑器中)   数据类型    说明                   
REG_SZ           字符串     文本字符串
REG_MULTI_SZ         多字符串    含有多个文本值的字符串
REG_BINARY          二进制数    二进制值,以十六进制显示.
REG_DWORD           双字      一个32位的二进制值,显示为8位的十六进制值.

各主键的简单介绍

  • HKEY_LOCAL_MACHINE  是一个显示控制系统和软件的处理键.HKLM键保存着计算机的系统信息.它包括网络和硬件上所有的软件设置.
  • HKEY_CLASSES_ROOT  是系统中控制所有数据文件的项.
  • HKEY_USERS  将缺省用户和目前登陆用户的信息输入到注册表编辑器
  • HKEY_CURRENT_USER  包含着在HKEY_USERS安全辨别里列出的同样信息
  • HKEY_CURRENT_CONFIG  包括了系统中现有的所有配置文件的细节.HKEY_CURRENT_CONFIG允许软件和设备驱动程序员很方便的更新注册表,而不涉及到多个配置文件信息. HKEY_LOCAL_MACHINE中同样的数据和任何注册表的变化都会同时的变化.

相关函数

创建键 RegCreateKeyEx(次函数主要用于生成键(目录))

函数原型

LONG RegCreateKeyEx(

HKEYhKey,                                 // handle to open key

LPCTSTRlpSubKey,                           // subkey name

DWORDReserved,                             // reserved

LPTSTRlpClass,                             // class string

DWORD dwOptions,                            // special options

REGSAMsamDesired,                          // desired security access

LPSECURITY_ATTRIBUTES lpSecurityAttributes, //inheritance

PHKEYphkResult,                            // key handle

LPDWORD lpdwDisposition                     //disposition value buffer

);

参数说明

  • hKey:   要打开键的句柄或以下预定义句柄

    • HKEY_CLASSES_ROOT
    • HKEY_CURRENT_USER
    • HKEY_LOCAL_MACHINE
    • HKEY_USERS
  • lpSubKey:   指向一个用于定义子键路径的字符串
  • Reserved,dwOptions,samDesired:   置0
  • lpClass,lpSecurityAttributes:   置NULL
  • phkResult:   用于接收键句柄
  • lpdwDisposition:   接收的相关信息,取值如下
    • REG_CREATED_NEW_KEY   创建成功
    • REG_OPENED_EXISTING_KEY    键已存在

返回值:If the function succeeds, the return value is ERROR_SUCCESS.

打开键 RegOpenKeyEx

函数原型

LONG RegOpenKeyEx(

HKEYhKey,         // handle to open key

LPCTSTRlpSubKey,  //subkey name

DWORDulOptions,   //reserved

REGSAMsamDesired, // security access mask

PHKEYphkResult    //handle to open key

);

参数说明

  • hKey:     要打开键的句柄或以下预定义句柄

    • HKEY_CLASSES_ROOT
    • HKEY_CURRENT_USER
    • HKEY_LOCAL_MACHINE
    • HKEY_USERS
  • lpSubKey:   指向一个用于定义子键路径的字符串
  • ulOptions:   保留位,置0
  • samDesired:   打开键后键的操作权限
  • phResult:   接收打开的键的句柄

返回值:If the function succeeds, the return value is ERROR_SUCCESS

删除键 RegDeleteKey

函数原型

LONG RegDeleteKey(

HKEYhKey,         // handle to open key

LPCTSTRlpSubKey   //subkey name

);

参数说明

  • hKey:   要打开键的句柄或以下预定义句柄

    • HKEY_CLASSES_ROOT
    • HKEY_CURRENT_USER
    • HKEY_LOCAL_MACHINE
    • HKEY_USERS
  • lpSubKey:   指向一个用于定义子键路径的字符串

返回值:If the function succeeds, the return value is ERROR_SUCCESS

修改/添加键值 RegSetValueEx

函数原型

LONG RegSetValueEx(

HKEYhKey,           // handle to key

LPCTSTRlpValueName, // value name

DWORDReserved,      //reserved

DWORDdwType,        //value type

CONST BYTE*lpData,  //value data

DWORD cbData         // size ofvalue data

);

参数说明

  • hKey:   打开键的句柄或以下预定义句柄

    • HKEY_CLASSES_ROOT
    • HKEY_CURRENT_USER
    • HKEY_LOCAL_MACHINE
    • HKEY_USERS
  • lpValueName:   键值的名称
  • Reserved:   保留位,置0
  • dwType:   键值的类型
  • lpData:   键值
  • cbData:   键值数据长度

返回值:If the function succeeds, thereturn value is ERROR_SUCCESS

删除键值 RegDeleteValue

函数原型

LONG RegDeleteValue(

HKEYhKey,            // handle to key

LPCTSTRlpValueName   //value name

);

参数说明

  • hKey:   打开键的句柄或以下预定义句柄

    • HKEY_CLASSES_ROOT
    • HKEY_CURRENT_USER
    • HKEY_LOCAL_MACHINE
    • HKEY_USERS
  • lpValueName:   键值的名称

返回值:If the function succeeds, the return value is ERROR_SUCCESS

读取键值 RegQueryValueEx

函数原型

LONG RegQueryValueEx(

HKEYhKey,            // handle to key

LPCTSTRlpValueName,  //value name

LPDWORDlpReserved,   //reserved

LPDWORD lpType,       // type buffer

LPBYTElpData,        //data buffer

LPDWORDlpcbData      //size of data buffer

);

参数说明

  • hKey:   打开键的句柄或以下预定义句柄

    • HKEY_CLASSES_ROOT
    • HKEY_CURRENT_USER
    • HKEY_LOCAL_MACHINE
    • HKEY_USERS
  • lpValueName:   键值的名称
  • Reserved:   保留位,置0
  • lpType:   接收键值的类型
  • lpData:   接收键值
  • lpcbData:   接收键值数据长度
 #include "stdafx.h"
#include <windows.h>
#include <iostream>
using namespacestd; int main()
{
HKEY hKey;
LPCTSTR lpRun =L"Software\\_MyTest";
DWORD state,dwtype,sizeBuff;
long lRet;
char reBuff[] ={}; //lRet =RegCreateKeyEx(HKEY_CURRENT_USER,lpRun,0,NULL,0,0,NULL,&hKey,&state);
//if(lRet == ERROR_SUCCESS)
//{
// if(state ==REG_CREATED_NEW_KEY)
// cout<<"表项创建成功"<<endl; //
// //关闭键
// RegCloseKey(hKey);
//}
//else if (state == REG_OPENED_EXISTING_KEY)
//{
// cout<<"表项已存在"<<endl;
//} //lRet = RegDeleteKey(HKEY_CURRENT_USER,lpRun);
//if (ERROR_SUCCESS == lRet)
//{
// cout<<"删除键成功"<<endl;
//}
//else
// cout<<"删除键失败"<<endl; lRet = RegOpenKeyEx(HKEY_CURRENT_USER,lpRun,,KEY_ALL_ACCESS,&hKey);
if (ERROR_SUCCESS==lRet)
{
cout<<"打开键成功"<<endl;
}
else
cout<<"打开键失败"<<endl; LPCTSTR KeyName= L"KeyName";
char KeyValue[];
DWORD type;
DWORD len = sizeof(KeyValue);
lRet = RegQueryValueEx(hKey,KeyName,,&type,(BYTE*)KeyValue,&len);
if (ERROR_SUCCESS==lRet)
{
cout<<"查询键值成功------"<<KeyValue<<endl;
}
else
cout<<"查询键值失败"<<endl; // LPCTSTR KeyName =L"KeyName";
//char KeyValue[] = "KeyValue";
//lRet = RegSetValueEx(hKey,KeyName,0,REG_SZ,(BYTE*)KeyValue,20);
//if (ERROR_SUCCESS == lRet)
//{
// cout<<"写入键值成功"<<endl;
//}
//else
// cout<<"写入键值失败"<<endl; //LPCTSTR KeyName = L"KeyName";
//lRet = RegDeleteValue(hKey,KeyName);
//if (ERROR_SUCCESS == lRet)
//{
// cout<<"删除键值成功"<<endl;
//}
//else
// cout<<"删除键值失败"<<endl; return ;
}
===================================添加开机启动项============================================
bool AutoStart()
{
//程序路径
char strMyPath[MAX_PATH];
int retGMFN=GetModuleFileName(NULL,strMyPath,MAX_PATH);
if (retGMFN==)
{
return false;
} //写注册表,达到开机启动的效果
HKEY keyAutoStart;
char subKeyName[]="Software\\Microsoft\\Windows\\CurrentVersion\\Run";
LONG retROK=RegOpenKeyEx(HKEY_LOCAL_MACHINE,subKeyName,,KEY_ALL_ACCESS,&keyAutoStart);
if (retROK!=ERROR_SUCCESS)
{
int erro =GetLastError();
return false;
}
//添加启动项
char keyValueName[]="YunYaoHuLian_UpdateServer";
LONG retRSV=RegSetValueEx(keyAutoStart,keyValueName,,REG_SZ,(BYTE *)strMyPath,strlen(strMyPath));
if (retRSV!=ERROR_SUCCESS)
{
int erro =GetLastError();
return false;
} //不用就关闭
RegCloseKey(keyAutoStart); return true;
}

注册表操作(VC_Win32)的更多相关文章

  1. MFC学习 文件操作注册表操作

    c读写文件 void CFileView::OnRead() { FILE *pFile = fopen("1.txt", "r"); /*char ch[10 ...

  2. delphi 注册表操作(读取、添加、删除、修改)完全手册

    DELPHI VS PASCAL(87)  32位Delphi程序中可利用TRegistry对象来存取注册表文件中的信息. 一.创建和释放TRegistry对象 1.创建TRegistry对象.为了操 ...

  3. CRegKey 注册表操作

    CRegKey 注册表操作 标签: accessnulluserpathbyteie 2011-11-03 13:55 3477人阅读 评论(0) 收藏 举报  分类: win32(7)  1.简介 ...

  4. C# 我的注册表操作类

    using System; using System.Collections.Generic; using System.Text; using Microsoft.Win32; using Syst ...

  5. Delphi的注册表操作

    转帖:Delphi的注册表操作 2009-12-21 11:12:52 分类: Delphi的注册表操作 32位Delphi程序中可利用TRegistry对象来存取注册表文件中的信息.     一.创 ...

  6. C#注册表操作类--完整优化版

    using System; using System.Collections.Generic; using System.Text; using Microsoft.Win32; namespace ...

  7. 《天书夜读:从汇编语言到windows内核编程》八 文件操作与注册表操作

    1)Windows运用程序的文件与注册表操作进入R0层之后,都有对应的内核函数实现.在windows内核中,无论打开的是文件.注册表或者设备,都需要使用InitializeObjectAttribut ...

  8. C#注册表操作类(完整版) 整理完整

    /// <summary> /// 注册表基项静态域 /// /// 主要包括: /// 1.Registry.ClassesRoot 对应于HKEY_CLASSES_ROOT主键 /// ...

  9. QSettings配置读写-win注册表操作-ini文件读写

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QSettings配置读写-win注册表操作-ini文件读写     本文地址:http:// ...

随机推荐

  1. 使用Android Studio过程中,停留在“Building ‘工程名’ Gradle project info”的解决方法

    http://www.loverobots.cn/in-the-process-of-using-studio-android-the-solution-of-the-project-info-gra ...

  2. Tomcat学习笔记(二)—— 一个简单的Servlet容器

    1.简介:Servlet编程是通过javax.Servlet和javax.servlet.http这两个包的类和接口实现的,其中javax.servlet.Servlet接口至关重要,所有的Servl ...

  3. HDU 1874 畅通工程续(模板题——Floyd算法)

    题目: 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多.这让行人很困扰 ...

  4. github 中删除仓库

    删除时,填充的名字是库的名字

  5. Vue版本过渡变化

    到了2.0以后,有哪些变化: 在每个组件模板,不在支持片段代码 之前: <template id="aaa"> <h3>我是组件</h3>< ...

  6. Powerdesigner+PostgreSQL

    1.准备软件 Powerdesigner PostgreSQL PostgreSQL ODBC驱动程序: psqlODBC,网址:http://www.postgresql.org/ftp/odbc/ ...

  7. 更改sql多条数据,更新替换字符串中固定的字符串

    需求产生的背景: 数据库里建库时插入了字典数据,可是这个字典数据,有一些是不准确的,所以就需要把一些固定的数据查出来替换掉. 问题解决逻辑: 大体逻辑是,首先把固定需要替换的字符串提取出来,赋值给变量 ...

  8. linux 动态库的符号冲突问题

    最近,给同事定位了一个符号表的冲突问题,简单记录一下. A代码作为静态链接库,被包含进了B代码,然后编译成了动态链接库,B.so A代码同时作为静态链接库,被编译进入了main的主代码. main函数 ...

  9. 通过Azure Powershell获取asm及arm虚拟机的配置信息

    1.asm虚拟机可以使用类似如下Azure Powershell命令获取虚拟机的基本信息,包括发行版本,虚拟机名称及size[备注:虚拟机需要是使用平台image创建的] PS C:\Users\he ...

  10. linux批量添加10个用户并将其随机密码和用户名写入文件

    需求: 批量新建10个测试用户,并且让其密码随机,把用户名和密码写入一个文件,并有创建时间和创建者 #!/usr/bin/python # -*- coding: utf-8 -*- import o ...