14、HOOK和数据库访问

简介: 一、HOOK  1、局部钩子       OS感知鼠标或键盘事件,产生相应的消息,把此消息放到应用程序的消息队列中,应用程序通过调用GetMessage函数取出消息,然后调用DispatchMessage函数将这条消息调度给OS,OS会调用在设计窗口类时指定的应用程序窗口过程对这一消息进行处理。

一、HOOK 

1、局部钩子 

wps_clip_image-20309 

   OS感知鼠标或键盘事件,产生相应的消息,把此消息放到应用程序的消息队列中,应用程序通过调用GetMessage函数取出消息,然后调用DispatchMessage函数将这条消息调度给OS,OS会调用在设计窗口类时指定的应用程序窗口过程对这一消息进行处理。

        可以通过SetWindowsHookEx来安装一个HOOK钩子过程;类似于必经道路上的路卡或查哨的;Before terminating, an application must call the UnhookWindowsHookEx function to free system resources associated with the hook. 

最后安装的钩子总是排在钩子链的前面。通过CallNextHookEx passes the

hook information to the next hook procedure in the current hook chain. A hook

procedure can call this function either before or after processing the hook information.

    虚拟键盘的宏都是以“VK_”开头的。

示例代码

 

代码
 
   
// 2
LRESULT CALLBACK MouseProc(
int nCode, // hook code
WPARAM wParam, // message identifier
LPARAM lParam // mouse coordinates
)
{
return 1 ;
}

LRESULT CALLBACK KeyboardProc(
int code, // hook code
WPARAM wParam, // virtual-key code
LPARAM lParam // keystroke-message information
)
{
if (VK_F2 == wParam)
{
SendMessage(g_hWnd,WM_CLOSE,
0 , 0 );
UnhookWindowsHookEx(g_hMouse);
UnhookWindowsHookEx(g_hKeyboard);
}
return 1 ;
}

// 1

int cxScreen,cyScreen;
cxScreen
= GetSystemMetrics(SM_CXSCREEN);
cyScreen
= GetSystemMetrics(SM_CYSCREEN);
SetWindowPos(
& wndTopMost, 0 , 0 ,cxScreen,cyScreen,SWP_SHOWWINDOW);
SetHook(m_hWnd);

2、全局钩子

如果想让所有进程都可以调用钩子程序,则必须把安装钩子的代码放到动态库中去。The global hooks are a shared resource, and installing one affects all applications

in the same desktop as the calling thread. All global hook functions must be in

libraries. Global hooks should be restricted to special-purpose applications or to use as a

development aid during application debugging. Libraries that no longer need a hook

should remove its hook procedure.

3、涉及的API

1)GetModuleHandle

The GetModuleHandle function retrieves a module handle for the specified module if the

file has been mapped into the address space of the calling process.

2)SetWindowsHookEx

Installs an application-defined hook procedure into a hook chain。

有两种方法得到该函数的第三个参数:

法一:保存DllMain函数传进来的DLL句柄。

 

BOOL WINAPI DllMain(
HINSTANCE hinstDLL, // handle to the DLL module
DWORD fdwReason, // reason for calling function
LPVOID lpvReserved // reserved
)
{
g_hInst=hinstDLL;
}
  法二:通过GetModuleHandle函数。

3)CWnd::SetWindowPos

to change the size, position, and Z-order of child, pop-up, and top-level windows.

4)GetSystemMetrics

Retrieves the specified system metric or system configuration setting.

http://msdn.microsoft.com/en-us/library/ms724385%28VS.85%29.aspx

4、写入时复制机制

为了解决多个进程访问同一份DLL中全局共享变量,而带来程序不确定问题,引入写入时复制机制。

wps_clip_image-11633

图示 P749 写入时复制机制

    一个进程想修改DLL数据页面(2)上的数据(该数据可以被多个进程共享)时,OS会分配一个新的页面,并将数据页面(2)上的数据复制一份到这个新页面中,然后断开数据页(2)到这个进程数据空间的映射,将新的页面映射到该进程的地址空间。

5、创建共享节

    由上节可见,由于写入时复制机制,如果多个进程真的想共享一个变量的话,倒成了一个问题。

有两种方法来创建一个真正意义的全局共享变量。

法一:创建共享节

#pragma data_seg("MySec") //MySec为节名
HWND g_hWnd=NULL;
#pragma data_seg()
#pragma comment(linker,"/section:MySec,RWS") //Read,Write,Share
Dumpbin [Headers] 查看各节的信息列表

法二:在def模块中定义

LIBRARY Hook
EXPORTS
SetHook @2
SEGMENTS
MySec Read Write Share
6、获取密码

    安装消息钩子WH_GETMESSAGE,得到WM_GETTEXT消息的相关信息,从该消息的附加参数中就可以得到文本框内的密码信息。

二、数据库

1、关于数据库的几个新名词

1)ODBC

ODBC(Open Database Connectivity),开放数据库互连。ODBC是上个世纪八十年代末九十年代初出现的技术,它为编写关系数据库的客户软件提供了一种统一的接口。ODBC提供一个单一的API,可用于处理不同数据库的客户应用程序。使用ODBC API的应用程序可以与任何具有ODBC驱动程序的关系数据库进行通信。wps_clip_image-3688

2)OLE DB

    OLE DB,对象链接与嵌入数据库。 OLE DB在两个方面对ODBC进行了扩展。首先, OLE DB提供了一个数据库编程的COM接口;第二, OLE DB提供了一个可用于关系型和非关系型数据源的接口。 OLE DB的两个基本结构是OLE DB提供程序(Provider)和OLE DB用户程序(Consumer)。

    OLE(Object Linking and Embedding) DB中的对象主要包括数据源对象、阶段对象、命令对象和行组对象。使用OLE DB的应用程序会用到如下的请求序列:初始化OLE连接到数据源、发出命令、处理结果、释放数据源对象。

3)ADO

ADO (ActiveX Data Objects,ActiveX数据对象)建立在OLE DB 之上,ADO是一个OLE DB用户程序,即他本身是一个Consumer,也是一个COM组件。ADO简化了OLE DB,提供了对自动化的支持,使得像VBScript这样的脚本语言也能够使用ADO访问数据库。

wps_clip_image-15314

    如何采用ADO技术访问数据库的话,实际调用过程是:ADO客户程序通过ADO再访问OLE DB提供程序,这样访问速度就要慢一些。

ADO中有三个核心对象:

(1) Connection对象 表示到数据库的连接,它管理应用程序和数据库之间的通信。

(2) Command对象 用来处理重复执行的查询,或处理需要检查在储存过程调用中的输出或返回参数的值的查询。有一个ActiveConnection属性,该属性用来引用Connection对象。

(3) Recordset对象 用来获取数据,存放查询的结果,这些结果由数据的行(记录)和列(字段)组成。每一列都存放在Recordset的Fields集合中的一个Field对象中。有一个ActiveConnection属性,该属性用来引用Connection对象。

    在利用ADO访问数据库时,VB比VC更容易使用。

 

 

目录
相关文章
|
7月前
|
消息中间件 缓存 监控
优化微服务架构中的数据库访问:策略与最佳实践
在微服务架构中,数据库访问的效率直接影响到系统的性能和可扩展性。本文探讨了优化微服务架构中数据库访问的策略与最佳实践,包括数据分片、缓存策略、异步处理和服务间通信优化。通过具体的技术方案和实例分析,提供了一系列实用的建议,以帮助开发团队提升微服务系统的响应速度和稳定性。
|
4月前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
123 11
|
5月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
110 3
|
5月前
|
SQL Java 数据库连接
打破瓶颈:利用Java连接池技术提升数据库访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,避免了频繁的连接建立和断开,显著提升了数据库访问效率。常见的连接池库包括HikariCP、C3P0和DBCP,它们提供了丰富的配置选项和强大的功能,帮助优化应用性能。
150 2
|
7月前
|
消息中间件 缓存 监控
优化微服务架构中的数据库访问:策略与实践
随着微服务架构的普及,如何高效管理和优化数据库访问成为了关键挑战。本文探讨了在微服务环境中优化数据库访问的策略,包括数据库分片、缓存机制、异步处理等技术手段。通过深入分析实际案例和最佳实践,本文旨在为开发者提供实际可行的解决方案,以提升系统性能和可扩展性。
|
7月前
|
SQL NoSQL Java
彻底革新你的数据库操作体验!Micronaut数据访问技巧让你瞬间爱上代码编写!
【9月更文挑战第10天】Java开发者们一直在寻找简化应用程序与数据库交互的方法。Micronaut作为一个现代框架,提供了多种工具和特性来提升数据访问效率。本文介绍如何使用Micronaut简化数据库操作,并提供具体示例代码。Micronaut支持JPA/Hibernate、SQL及NoSQL(如MongoDB),简化配置并无缝集成。通过定义带有`@Repository`注解的接口,可以实现Spring Data风格的命名查询。
134 6
|
7月前
|
SQL 存储 关系型数据库
C#一分钟浅谈:使用 ADO.NET 进行数据库访问
【9月更文挑战第3天】在.NET开发中,与数据库交互至关重要。ADO.NET是Microsoft提供的用于访问关系型数据库的类库,包含连接数据库、执行SQL命令等功能。本文从基础入手,介绍如何使用ADO.NET进行数据库访问,并提供示例代码,同时讨论常见问题及其解决方案,如连接字符串错误、SQL注入风险和资源泄露等,帮助开发者更好地利用ADO.NET提升应用的安全性和稳定性。
507 7
|
7月前
|
SQL 关系型数据库 分布式数据库
PolarDB Proxy配置与优化:提升数据库访问效率
【9月更文挑战第6天】PolarDB是阿里云推出的高性能分布式关系型数据库,PolarDB Proxy作为其关键组件,位于客户端与PolarDB集群间,负责SQL请求的解析与转发,并支持连接池管理、SQL过滤及路由规则等功能。本文详细介绍了PolarDB Proxy的配置方法,包括连接池、负载均衡和SQL过滤设置,并探讨了监控调优、缓存及网络优化策略,以帮助提升数据库访问效率。
139 1
|
8月前
|
开发者 UED Java
Play Framework惊天秘密:如何让异常处理优雅得像芭蕾舞?
【8月更文挑战第31天】在Web应用开发中,异常处理至关重要,直接影响应用稳定性和用户体验。Play Framework作为轻量级Java Web框架,提供了基于Scala偏函数的灵活异常处理机制。通过实现`HttpErrorHandler`接口可定义全局异常逻辑,而在控制器中使用try-catch块则能捕获特定异常。定义自定义异常类也有助于表示特定错误情况。最佳实践包括保持处理一致性、提供有用错误信息、记录日志及分类处理异常。掌握这些技巧,能使Play应用更健壮可靠。
92 1
|
8月前
|
SQL 关系型数据库 数据库连接
探索研究Ruby 数据库访问
【8月更文挑战第31天】
60 1

热门文章

最新文章

下一篇
oss创建bucket