2020.4.10个人总结

本文探讨了反调试技术,如使用isdebuggerpresent()函数进行调试检测,并介绍了通过patch或hook方式绕过的可能。深入解析了调试器工作原理,特别是在Linux平台下ptrace系统调用的作用,以及内存断点和硬件断点的区别与应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

反调试:
了解了一些反调试的api,比如isdebuggerpresent()这个函数,会不断轮询ptraceid来判断是否被调试,然后也看到师傅的博客里,是通过patch或者hook那个函数,修改返回值的方式绕过,虽然没碰到到,但是理论上是可行的。
调试器原理:
同时也理解了下那些调试器是如何做到调试的,在linux平台下提供了一个ptrace的系统调用,通过传入的参数不同,对被调试的进程有不同的行为,当被调试进程载入调试器时,就成为了调试器的子进程,默认传入了一个REMOTEME的参数,这时调试器就可以控制和调试进程了,感觉windows上也一样,差不多。
内存断点和硬件断点:
内存断点是通过给内存页设置属性,当执行到断点位置,触发0e异常,检查这个地址是不是我们打断点的位置,系统执行异常处理程序,反馈给调试器,同时内存断点可以下很多个,但是速度很慢
硬件断点是由cpu里四个调试寄存器管理的,速度比较快,也是触发异常。

明日目标:讨论数据结构课设,java作业完成,深入理解计算机系统看20页。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值