首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Hack ELF Loader:用户态execve

下的loader:用户态execve。...研究用户态execve的实现,起初是从攻击的方向去思考的,在linux主机安全中,使用shell命令进行攻击是非常常见的场景,无论是横向移动,还是种马,很难不应用shell命令。...在之前的文章中,无"命令"反弹shell-逃逸基于execve的命令监控(上) 分享过关于shell命令的各种监控方式,其中最难绕过的是内核态的execve监控。...二.How:如何设计linux elf loader how 用户态execve 是仿照linux内核中execve syscall的原理 ,在应用层实现程序的加载和运行,如果做过windows pe...elf loader需要实现三个方面的内容: 映射可执行文件的LOAD段到内存中,并判断是否对齐 搜索INTERP段,如果存在,则像装载可执行文件一样装载链接器 初始化数据包括设置辅助信息数组,环境变量和参数

2.1K10
您找到你想要的搜索结果了吗?
是的
没有找到

Linux Linux内核参数调优

关于调优的建议: 1、出错时,可以查看操作系统日志,可能会找到一些有用的信息 2、尽量不要“批量”修改内核参数,笔者就曾这么干过,结果“调优”后,性能反而下降,事务出错数反而增加,所以,调优的时候可以考虑逐个参数进行调优...说明:我也不是很懂,参考自网络整理了下可能需要调整的一些参数 net.core.wmem_max=124928 发送套接字缓冲区大小的最大值(以字节为单位),参考值873200 net.core.rmem_max...通过配置TCP_TW_REUSE参数,来释放TIME_WAIT状态的端口号给新连接使用 net.ipv4.tcp_tw_recycle=1 表示开启TCP连接中TIME-WAIT sockets的快速回收...net.ipv4.tcp_fin_timeout=30 默认值60,这个参数决定了它保持在FIN-WAIT-2状态的时间,参考值 30(一般来说FIN-WAIT-2的连接也极少) net.ipv4....当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭; 以下几个参数文件需要打开防火墙才会存在 net.netfilter.nf_conntrack_max=

6.7K31

反弹shell-逃逸基于execve的命令监控(上)

但是我们在开发linux程序的时候,执行系统命令,并没有直接使用execve系统调用,这是因为libc/glibc库对execve系统调用封装成了函数,方便我们调用。...3.2 假日志 - 混淆进程名与进程参数 1.混淆进程名 在linux中有个syscall,名字叫做memfd_create (http://man7.org/linux/man-pages/man2/...2.混淆进程参数 使用的是linux中另一个syscall: ptrace。...大体的操作流程如下: 第一步:首先我们fork出来一个子进程,然后在子进程中先调用ptrace,接着执行execve("ls xxxxxx"),这个时候基于execve监控到的就是一个假参数。...第二步:既然传入的是假参数,那肯定是是无法执行到想要的结果,这个时候父进程等待子进程execve后停下来,然后修改传入参数的寄存器,将其修改为 -alh,最后接着让子进程继续运行即可。

3K20

Linux进程启动过程分析do_execve(可执行程序的加载和运行)---Linux进程的管理与调度(十一)

同时我们需要一种方法来保存可执行程序的信息, 比如可执行文件的路径, 运行的参数和环境变量等信息,即linux_bin_prm结构 struct linux_bin_prm结构描述一个可执行程序 linux_binprm...(getname(filename), argv, envp); } 通过参数传递了寄存集合和可执行文件的名称(filename), 而且还传递了指向了程序的参数argv和环境变量envp的指针 参数...v=4.5#L1628 更早期实现linux-2.4 linux-3.18引入execveat之前do_execve实现 linux-3.19~至今引入execveat之后do_execve实现 do_execveat...程序的加载do_execve_common和do_execveat_common 早期linux-2.4中直接由do_execve实现程序的加载和运行 linux-3.18引入execveat之前...sys_execve接受参数:1.可执行文件的路径 2.命令行参数字符串 3.环境变量字符串 sys_execve是调用do_execve实现的。

3.7K31

无命令反弹shell-逃逸基于execve的命令监控(上)

3.2 假日志 - 混淆进程名与进程参数 1.混淆进程名 在linux中有个syscall,名字叫做memfd_create (http://man7.org/linux/man-pages/man2/...2.混淆进程参数 使用的是linux中另一个syscall: ptrace。...大体的操作流程如下: 第一步:首先我们fork出来一个子进程,然后在子进程中先调用ptrace,接着执行execve("ls xxxxxx"),这个时候基于execve监控到的就是一个假参数。...第二步:既然传入的是假参数,那肯定是是无法执行到想要的结果,这个时候父进程等待子进程execve后停下来,然后修改传入参数的寄存器,将其修改为 -alh,最后接着让子进程继续运行即可。...执行loader依然用的是execve 对输入参数没有隐藏 最优的效果是 无文件,无命令,无进程,无参数。 接下来的文章,我们会继续优化这个方案,达到理想的效果。

1.5K20

Linux内核参数调优

用法: vim /etc/sysctl.conf #修改内容 sysctl -p #生效 相关参数仅供参考,具体数值还需要根据机器性能,应用场景等实际情况来做更细微调整。...net.core.netdev_max_backlog = 400000 #该参数决定了,网络设备接收数据包的速率比内核处理这些包的速率快时,允许送到队列的数据包的最大数目。...net.core.somaxconn = 100000 #Linux kernel参数,表示socket监听的backlog(监听队列)上限 net.core.wmem_default = 11059200...net.ipv4.tcp_fin_timeout = 10 #表示如果套接字由本端要求关闭,这个参数决定了它保持在FIN-WAIT-2状态的时间。...参数值为布尔值,1表示接受,0表示不接受。 #在充当网关的linux主机上缺省值为1,在一般的linux主机上缺省值为0。 #从安全性角度出发,建议你关闭该功能。

3.9K20

Linux内核参数调优

再来看看linux内核常用的参数优化: Linux内核参数优化可以根据不同的应用场景进行调整,以提高系统性能和稳定性。...以下是一些常见的Linux内核参数优化: 文件系统缓存参数:文件系统缓存是Linux系统中的重要性能因素之一,可以通过调整以下参数进行优化: vm.dirty_background_ratio:设置脏页...网络参数:网络性能是Linux系统中的另一个关键因素,可以通过以下参数进行优化: net.core.somaxconn:设置TCP半连接队列的最大长度,建议设置为1024或更高。...内存管理参数:内存管理是Linux系统的核心,可以通过以下参数进行优化: vm.swappiness:设置内存交换的程度,建议设置为10-15。...进程管理参数:进程管理是Linux系统的另一个重要方面,可以通过以下参数进行优化: kernel.pid_max:设置系统中最大进程ID号,建议设置为65536或更高。

44721

Linux:procmeminfo参数详细解释

Linux:/proc/meminfo参数详细解释 一、Linux内存总览图 二、meminfo参数的详细介绍 /proc/meminfo是了解Linux系统内存使用状况的主要接口,我们最常用的”free...内存黑洞 追踪Linux系统的内存使用一直是个难题,很多人试着把能想到的各种内存消耗都加在一起,kernel text、kernel modules、buffer、cache、slab、page table...因为Linux kernel并没有滴水不漏地统计所有的内存分配,kernel动态分配的内存中就有一部分没有计入/proc/meminfo中。...在x86系统上Linux的内核栈大小是固定的8K或16K(可参阅我以前的文章:内核栈溢出)。...: 0 HugePages_Free: 0 HugePages_Rsvd: 0 HugePages_Surp: 0 Hugepagesize: 2048 kB HugePages_Total 对应内核参数

77320

linux ftp命令参数全集

linux ftp命令参数是我们常用的服务器控制手段。那么我们现在就来介绍一些linux ftp命令参数。希望能帮助大家快速查阅,这些命令都是常用的,肯定会对您有所帮助。...binary(或bi) 将文档传送类型配置为二进制。 FTP> bye(或by) 结束和远程电脑的linux ftp命令参数会话并退出linux ftp命令参数。 FTP> cd 更改远程电脑上的工作目录...,将显示本地电脑中当前的工作目录。 FTP>literal 将参数逐字发送到远程linux ftp命令参数服务器。将返回单个的linux ftp命令参数回复代码。 格式:literal argument...。能够通过 IP 地址或电脑名称指定电脑(DNS 或主机文档必须可用)。假如自动登录打开(默认),ftp 还将尝试自动将用户登录到linux ftp命令参数服务器port 指定用来联系linux ftp...ftp命令参数会话并退出linux ftp命令参数。 FTP>quote 将参数逐字发送到远程linux ftp命令参数服务器。将返回单个的linux ftp命令参数回复代码。 Quote 和literal

11.6K90
领券