南京大学计算机基础(四)踩坑笔记

第六周 缓冲区溢出章节

bang问题:

rumble问题:

仔细分析汇编和栈的调用,这道题挺难的!【搞了我3个小时,真的别只用gdb,用ida静态结合gdb动态才是正解。】

  • 用ida标一标,其中的write_here是为了随机地址防止你直接push的。write_here存储的字符串是你大写的cookie值,比如我-u 1234的cookie是0x6eecf91d,那么这里就是"6EECF91D"。
  • 然后注意的是memcmp比较的是地址,所以你getbuf中应该push一个地址。
  • 缓冲区的输入应该长成这样,注意到我的"6EECF91D"的十六进制是0x43454536 0x44313946【注意要颠倒过来】。
  • 然后push %esp表示当前地址。
  • 注意到栈帧中第一个参数是$ebp+8,所以你要压入一个"返回地址",我这里压的是0x11111111占位。
相关推荐
岑梓铭2 天前
考研408《计算机组成原理》复习笔记,第四章(1)——指令系统概念(指令字长、N地址指令、定长和变长操作码)
笔记·考研·408·计算机组成原理·计组
岑梓铭2 天前
考研408《计算机组成原理》复习笔记,第四章(3)——指令集、汇编语言
笔记·考研·408·计算机组成原理·计组
nju_spy5 天前
机器学习 - Kaggle项目实践(1)Titanic
人工智能·机器学习·数据分析·kaggle·数据清洗·南京大学·titanic
Zenexus5 天前
VSCODE+GDB+QEMU调试内核
linux·vscode·qemu·gdb
nju_spy7 天前
周志华院士西瓜书实战(二)MLP+SVM+贝叶斯分类器+决策树+集成学习
决策树·随机森林·机器学习·adaboost·svm·mlp·南京大学
nju_spy9 天前
李宏毅深度学习教程 第12-13章 对抗攻击 + 迁移学习transfer learning
人工智能·深度学习·迁移学习·黑盒攻击·南京大学·对抗攻击·领域偏移
nju_spy1 个月前
NJU 凸优化导论(9) 对偶(II)KKT条件+变形重构
人工智能·算法·机器学习·kkt条件·凸优化·对偶·南京大学
nju_spy1 个月前
周志华《机器学习导论》第5章 支持向量机SVM
人工智能·机器学习·支持向量机·kkt条件·核函数·南京大学·拉格朗日乘数法
岑梓铭1 个月前
考研408《计算机组成原理》复习笔记,第三章(5)——磁盘存储器
笔记·考研·408·计算机组成原理·计组
nju_spy1 个月前
周志华《机器学习导论》第8章 集成学习 Ensemble Learning
人工智能·随机森林·机器学习·集成学习·boosting·bagging·南京大学