2020.4.10个人总结

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值