[发明专利]钩子处理方法及装置有效

专利信息
申请号: 201711392044.3 申请日: 2017-12-20
公开(公告)号: CN108345526B 公开(公告)日: 2021-06-11
发明(设计)人: 颜华甲 申请(专利权)人: 北京金山安全管理系统技术有限公司
主分类号: G06F11/30 分类号: G06F11/30;G06F21/55
代理公司: 北京康信知识产权代理有限责任公司 11240 代理人: 赵囡囡
地址: 100013 北京市朝阳区北三环*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 钩子 处理 方法 装置
【权利要求书】:

1.一种钩子处理方法,其特征在于,包括:

获取API Hook所钩挂的函数;

调用所述函数;

判断调用所述函数之后所述API Hook是否监控到所述函数被调用;

如果所述API Hook未监控到所述函数被调用,则确定所述API Hook被卸载;

在确定所述API Hook被卸载的情况下,根据所述API Hook被卸载的原因的类型或所述API Hook的优先级判断是否重新将所述API Hook钩挂在所述函数上。

2.根据权利要求1所述的方法,其特征在于,判断调用所述函数之后所述API Hook是否监控到所述函数被调用包括:

判断调用所述函数之后程序的运行是否会回到所述API Hook中,以判断所述API Hook是否监控到所述函数被调用,其中,所述函数包括在所述程序中。

3.根据权利要求1所述的方法,其特征在于,在判断重新将所述API Hook钩挂在所述函数上的情况下,所述方法还包括:

重新将所述API Hook钩挂在所述函数上。

4.根据权利要求3所述的方法,其特征在于,重新将所述API Hook钩挂到所述函数上包括以下之一:

通过重新修改函数指针,将所述API Hook钩挂到所述函数上;

通过修改所述函数的代码,将所述API Hook钩挂到所述函数上。

5.一种钩子处理装置,其特征在于,包括:

第一获取模块,用于获取API Hook所钩挂的函数;

调用模块,用于调用所述函数;

第一判断模块,用于判断调用所述函数之后所述API Hook是否监控到所述函数被调用;

第一确定模块,用于如果所述API Hook未监控到所述函数被调用,则确定所述APIHook被卸载;

其中,所述装置还用于在确定所述API Hook被卸载的情况下,根据所述APIHook被卸载的原因的类型或所述API Hook的优先级判断是否重新将所述API Hook钩挂在所述函数上。

6.根据权利要求5所述的装置,其特征在于,所述第一判断模块包括:

判断单元,用于判断调用所述函数之后程序的运行是否会回到所述API Hook中,以判断所述API Hook是否监控到所述函数被调用,其中,所述函数包括在所述程序中。

7.根据权利要求5所述的装置,其特征在于,所述装置还包括:

钩挂模块,用于重新将所述API Hook钩挂在所述函数上。

8.根据权利要求7所述的装置,其特征在于,所述钩挂模块包括以下之一:

第一钩挂单元,用于通过重新修改函数指针,将所述API Hook钩挂到所述函数上;

第二钩挂单元,用于通过修改所述函数的代码,将所述API Hook钩挂到所述函数上。

9.一种存储介质,其特征在于,所述存储介质包括存储的程序,其中,所述程序运行时执行权利要求1至4中任一项所述的方法。

10.一种处理器,其特征在于,所述处理器用于运行程序,其中,所述程序运行时执行权利要求1至4中任一项所述的方法。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京金山安全管理系统技术有限公司,未经北京金山安全管理系统技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201711392044.3/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top