[发明专利]应用程序反调试的方法、装置及电子设备有效
申请号: | 201811595266.X | 申请日: | 2018-12-25 |
公开(公告)号: | CN109684795B | 公开(公告)日: | 2023-01-24 |
发明(设计)人: | 向波;李东 | 申请(专利权)人: | 成都卫士通信息产业股份有限公司 |
主分类号: | G06F21/14 | 分类号: | G06F21/14 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 罗满 |
地址: | 610041 四*** | 国省代码: | 四川;51 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 应用程序 调试 方法 装置 电子设备 | ||
本申请公开了一种应用程序反调试的方法,包括:在应用程序启动时,启动线程检测应用程序所在的内存空间中是否存在断点指令;若否,则检测应用程序的核心代码所在的地址空间中是否存在断点指令;当应用程序的核心代码所在的地址空间中存在断点指令时,调用安全终止流程令应用程序停止运行。本申请所提供的技术方案,能够准确的检测应用程序被调试的状态,使得攻击者无法通过修改运行环境来避开调试检测,检测到被调试后终止应用程序的运行,能很好的保护反调试代码,进而保护应用程序的代码安全。本申请同时还提供了一种应用程序反调试的装置、电子设备及计算机可读存储介质,具有上述有益效果。
技术领域
本申请涉及应用程序调试领域,具体地,涉及一种应用程序反调试的方法、装置、电子设备及计算机可读存储介质。
背景技术
随着智能手机的普及,各类应用程序逐渐进入人们的工作、生活、娱乐,和金融支付相关的应用程序也被广使用。这也带来了安全问题,攻击者可以通过分析应用程序的代码,查找漏洞,制作病毒,窃取用户的信息。对应用程序代码的有效保护可以很好的提高应用程序的安全性,而反调试技术能有效的阻止攻击者对应用程序的调试分析,达到有效保护应用程序的目的。
相关反调试技术主要是通过检查进程调试状态,运行环境调试服务的方式确定应用程序是否正在被调试攻击,然后通过结束进程或运行一段错误逻辑的方式结束应用程序,以防止应用程序被调试分析。
然而,相关反调试技术不能准确的检测应用程序是否被调试,攻击者能够通过修改内核代码来改变进程调试状态为固定值,或修改调试服务的名称、使用端口号方式来规避应用程序对调试状态的检查,使反调试代码失效。
因此,如何实现应用程序的反调试是本领域技术人员目前需要解决的技术问题。
发明内容
本申请的目的是提供应用程序反调试的方法、装置、电子设备及计算机可读存储介质,用于实现应用程序的反调试。
为解决上述技术问题,本申请提供一种应用程序反调试的方法,该方法包括:
在应用程序启动时,启动线程检测所述应用程序所在的内存空间中是否存在断点指令;
当所述应用程序所在的内存空间中不存在所述断点指令时,检测所述应用程序的核心代码所在的地址空间中是否存在所述断点指令;
当所述应用程序的核心代码所在的地址空间中存在所述断点指令时,调用安全终止流程令所述应用程序停止运行。
可选的,当所述应用程序所在的内存空间中存在所述断点指令时,还包括:
调用所述安全终止流程令所述应用程序停止运行。
可选的,调用所述安全终止流程令所述应用程序停止运行,包括:
获取所述应用程序进程的栈指针;
根据所述栈指针清空栈上函数调用的信息,并向程序计数器赋随机值,以使所述应用程序运行时出现崩溃错误,进而停止运行。
可选的,检测所述应用程序的核心代码所在的地址空间中是否存在所述断点指令,包括:
在所述应用程序运行的逻辑中插入断点检查代码;其中,所述断点检测代码在所述应用程序运行时随着程序逻辑的执行被调用;
调用所述断点检测代码检测所述应用程序的核心代码所在的地址空间是否存在所述断点指令。
本申请还提供一种应用程序反调试的装置,该装置包括:
第一检测模块,用于在应用程序启动时,启动线程检测所述应用程序所在的内存空间中是否存在断点指令;
第二检测模块,用于当所述应用程序所在的内存空间中不存在所述断点指令时,检测所述应用程序的核心代码所在的地址空间中是否存在所述断点指令;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于成都卫士通信息产业股份有限公司,未经成都卫士通信息产业股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811595266.X/2.html,转载请声明来源钻瓜专利网。