用gdb.attach()在gdb下断点但没停下的情况及解决办法

在python中,如果导入了pwntools,就可以使用里面的gdb.attach(io)的命令来下断点。
但是这一次鼠鼠遇到了一个情况就是下了断点,但是仍然无法在断点处开始运行,奇奇怪怪。

这是我的攻击脚本

我们运行一下。

 可以看到其实已经运行起来了,也就是根本没有断下来。
判断有可能在io=process('./')的时候就已经开始运行了,因此我们下断点要掌握时机,我们只能在输入型函数后下断点才有用,例如gets() scanf()这样,例如我们可以下断点在0x080492B0 这里,然后 continue 一下就可以啦

还有一种方法就是在gdb.attach()后面紧跟一句pause(),然后按任意键继续,就可以停下了。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GDB是一种用来调试程序的工具,可以帮助开发者找到程序中的错误并进行修复。在Linux系统中,可以使用"gdb attach"命令来附加到正在运行的进程上进行调试。 通过"gdb attach"命令,我们可以将GDB连接到一个正在运行的Linux进程,然后可以查看和修改该进程的状态和内存内容,以进行调试。这对于已经在运行的程序出现问题时非常有用,尤其是在无法重新编译和运行程序的情况下。 使用"gdb attach"命令时,需要知道要附加到的进程的进程ID(PID)。可以通过使用"ps"命令或"top"命令来查找进程的PID。 具体使用方法为,在终端中输入"gdb attach <PID>",其中"<PID>"是要附加的进程的PID。然后GDB会连接到该进程,并提供一个交互式的调试界面。 在附加到进程后,可以使用GDB提供的各种命令来进行调试,比如查看变量的值、设置断点、单步执行等。可以通过"help"命令来查看GDB的各种命令和用法。 需要注意的是,使用"gdb attach"命令进行调试时,要确保目标进程有被其他调试器附加。如果有其他调试器已经附加到目标进程,那么GDB将无法成功附加并进行调试。 总结来说,"gdb attach"命令是在Linux系统中使用GDB进行程序调试的一种方式,通过将GDB连接到运行中的进程,可以查看和修改进程状态和内存内容,帮助开发者定位和修复程序中的错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值