黑客风云——风云网络
设为首页 加入收藏 我要投稿 网站地图

您现在的位置: 黑客风云 >> 黑客文章 >> 黑客进阶 >> 黑客编程 >> 正文
·完美空间提供500M免费AS04-10·企业安全之YY内网准入以04-09
·企业安全之意识与策略04-09·剑走偏锋:IIS漏洞利用04-09
·我来免费网提供100M免费04-09·1122mb.com提供20G超大免04-08
·映像劫持与反劫持技术04-07·让所有"暴力删除工具"无04-07
·入侵88red系统的详细过程04-07·Sql Injection脚本注入终04-07
·vbs+delphi 反弹后门生成04-07·飞讯网提供100MB免费PHP04-07
·突破SQL注入攻击时输入框04-04·结合内核和病毒技术的最04-04
·Real Player rmoc3260.d04-04·亿万网络今月最后为您提04-04
·php+mysql 5 sql inject04-03·Real Player rmoc3260.d04-03
·oblog文件下载漏洞04-03·免费啦提供1G-2G免费全能04-03
·完全解析网页后门和挂马04-02·一句话开3389(只测试过04-02
·萧萧免费空间网提供100M04-02·谷道免费空间网提供1G免04-01
·从本地入手解决双线路由03-31·sablog 1.6 多个跨站漏洞03-31
·富文本编辑器的跨站脚本03-31·Cookie注入是怎样产生的03-31
[组图]API对注册表进行操作(Delphi编程)
      ★★★★★

API对注册表进行操作(Delphi编程)

文章整理发布:黑客风云 文章来源:www.05112.com 更新时间:2007-7-30 8:43:27

下载源代码

一、注册表的组织结构

  
              图一

类比:Key有如文件夹,Value有如文件。
Value组成:Name/Type/Data, 通常指某Value就是指其Name。

二、目前的访问手段
regedit, regedt32,第三方软件,编程。
Windows提供了三种方式供编程实现:函数,Shell函数,CRegKey类(由ATL库提供,是对API的封装,简化了部分功能)。这三种方式的提供的函数大同小异;由于它们对注册表操作的函数都是原子动作,故功能强大却使用不便。
类比:dir浏览当前文件夹下的子文件夹和文件,却无法知道子文件夹中有什么;注册表操作函数也仅能浏览当前Key下的Subkey和Value,却无法知道Subkey中有什么。

三、面临的问题——本程序的目的
无法直接查询注册表中是否存在某一Key或Value。
为实现对注册表的查询,必须编程对注册表进行遍历。
递归函数是不二的选择。

图二

四、基本函数(以API为例):
1、RegOpenKeyEx
主要参数:欲访问键柄,子键路径,访问权限,返回键柄
欲访问键柄可以是5个预定义根键,也可以是返回键柄
子键路径如果是空串,表明直接打开欲访问键柄
返回的键柄可以直接指定为欲访问键柄
为加快处理速度,键柄用长整型表示
注:键的句柄,简称键柄

2、RegQueryKeyInfo
主要参数:欲访问键柄,返回子键数目

3、RegEnumKeyEx
主要参数:欲访问键柄,子键编号,返回某编号子键名
通过RegQueryKeyInfo返回的子键数目,再用RegEnumKeyEx逐个返回子键名

4、RegQueryValueEx
主要参数:欲访问键柄, 欲查询Value的Name
如果存在该Name,则返回ERROR_SUCCESS

五、算法设计:使用递归函数对注册表进行遍历
1、使用RegOpenKeyEx打开一个键
2、使用RegQueryValueEx查找是否存在欲查询的Value
   A、是:退出递归,并表示“已找到”
   B、否:使用RegQueryKeyInfo查找当前键下是否有子键
      I、否:当前键下无欲查找的Value
      II、是:逐个打开子键,并调用递归函数

六、算法流程图:
  
             图三

七、结束语——尚待改进之处
针对不同条件查找:目前查找的对象仅为value的name,改进可使其查找key和value的data。
模糊查找:该程序目前对字符串的搜索是精确查找,要使其功能更加强大,须加入字符串模糊匹配算法。
查找下一个符合条件的值:如果注册表中有多个满足条件的值,那么本程序只能查出第一个,对递归进行中断,再恢复,可实现下一次查找。

文章录入:cainiaowang    责任编辑:cainiaowang 
【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
VIP 专 区
Copyright @2006 黑客风云 ●业务联系:QQ 联系怪人 联系奇人 Email:给怪人发邮件 给奇人发邮件
ICP备案:冀06009886