当前位置: 首页 > news >正文

【pwn入门】用gdb实现第1个pwn

声明

本文是B站你想有多PWN学习的笔记,包含一些视频外的扩展知识。

有问题的源码

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
char sh[]="/bin/sh";
int func(char *cmd){system(cmd);return 0;
}int main(){char a[8] = {};char b[8] = {};puts("input:");gets(a);  // gets函数可以读取超过8个字节的数据,然后写入a,造成越界写bprintf(a);if(b[0]=='a'){ // b数组出现'a',即进入获取shell的分支func(sh);}return 0;
}

直接hack

gcc question_1.c -o question_1_x64

在这里插入图片描述

用gdb调试理解这个过程

1.查看断点应该设置哪个位置
在这里插入图片描述
在这里插入图片描述

2.设置断点
在这里插入图片描述
输入13个a
在这里插入图片描述
3.查看寄存器的值

p $rbp-0x10

在这里插入图片描述
往0x7fffffffe330前面多打几个内存看看

x/20gx 0x7fffffffe310

在这里插入图片描述
可以看到输入输入13个a后,成功将b数组的值也越界写成aaaaa,所以b[0] == 'a’的条件会满足。

用gdb改变寄存器的值hack

1.将断点打在main

b main

在这里插入图片描述
2.打印$rip的汇编

x/20i $rip

在这里插入图片描述
3.在分支比较处设置断点

b *0x5555555552ce

在这里插入图片描述

4.通过GDB设置寄存器的值
0x61就是a的ascii码
在这里插入图片描述

  1. 程序进入到获取shell的分支
    在这里插入图片描述
http://www.lryc.cn/news/181447.html

相关文章:

  • 用pyinstaller打包LGBM模型为ELF/EXE可执行文件
  • 软考中级—— 操作系统知识
  • 我们是否真的需要k8s?
  • 基于蜉蝣优化的BP神经网络(分类应用) - 附代码
  • 前端系列-1 HTML+JS+CSS基础
  • Learning Invariant Representation for Unsupervised Image Restoration
  • 1.4.C++项目:仿muduo库实现并发服务器之buffer模块的设计
  • AndroidStudio精品插件集
  • java图书管理系统
  • 大屏自适应容器组件-Vue3+TS
  • java图书信息管理
  • apache服务器出现No input file specified.解决方案
  • 你写过的最蠢的代码是?——全栈开发篇
  • 正点原子嵌入式linux驱动开发——TF-A初探
  • 【网安别学成开发】之——python篇
  • vue图片显示
  • S32K144 GPIO编程
  • 域名备案流程(个人备案,腾讯云 / 阿里云)
  • 子网ip和子网掩码的关系
  • openGauss学习笔记-88 openGauss 数据库管理-内存优化表MOT管理-内存表特性-使用MOT-MOT使用将磁盘表转换为MOT
  • 网络-Ajax
  • Autowired和Resource的关系
  • HashTable, HashMap, ConcurrentHashMap 之间的区别
  • Maven下载源码出现:Cannot download sources Sources not found for org.springframwork...
  • C进阶--字符函数和字符串函数介绍
  • 算法通关村第五关-二叉树遍历(层数优先)之经典问题:简单的层序遍历、层序遍历分层、自底向上的层序遍历
  • C++左右值及引用
  • 如何备份和恢复数据库
  • 简化数据库操作:探索 Gorm 的约定优于配置原则
  • 保姆级Anaconda安装教程