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

LD_PRELOAD 后门 | Linux 后门系列

LD_PRELOAD 都快被写烂了,基本都是绕过 disable_functions ,之后分析得也比较完整,比较复杂 其实知识点也就是一个加载顺序的问题,之前咱们已经针对PATH的加载路径劫持做了介绍...,这次原理没变,只不过是劫持函数,需要的知识点更高一些 动态链接库加载过程中会先加载 LD_PRELOAD 指向的变量,这样我们可以利用这个先加载来进行劫持正常的函数和命令 这次我们劫持 whoami...可以看到可执行文件 hook.so 已经完成了 设置 LD_PRELOAD ? 成功获取到反弹shell ,劫持成功。...加固后门 正常大家检查是否存在 LD_PRELOAD 后门的时候都是直接 echo $LD_PRELOAD ?...Tips: 使用 readonly 命令设置的环境变量不可修改 在有SUID,SGID存在的文件是无视 LD_PRELOAD 的,无法用 :LD_PRELOAD 劫持 这些命令的源码 git clone

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

什么是 Preload、Prefetch 和 Preconnect?

Preload Preload 是一个新的控制特定资源如何被加载的新的 Web 标准,这是已经在 2016 年 1 月废弃的 subresource prefetch 的升级版。...这个指令可以在 中使用,比如 。一般来说,最好使用 preload 来加载你最重要的资源,比如图像,CSS,JavaScript 和字体文件。...使用 Preload 的好处 使用 preload 指令的好处包括: 允许浏览器来设定资源加载的优先级因此可以允许前端开发者来优化指定资源的加载。...浏览器对 Preload 的支持 Chrome 50 在 2016 年 4 月添加了对 Preload 的支持,Opera 37 等浏览器也支持它。...(译者注,下图是 2018 年 7 月末浏览器对 preload 的支持情况) ? 可以读一下我们对 preload 的一篇深入分析的文章。

5.4K31

LD_PRELOAD 劫持 PWD 为什么失败了 | Linux 后门系列

这篇文章主要讲两个事情,第一个是Linux ELF文件共享库加载顺序,第二个是之前 LD_PRELOAD 劫持 pwd 失败的事情,第二件事我要大讲特讲,但对于大家帮助可能不会很大,为了解决这个问题我研究了一年...,所以别怪我话多了 Linux ELF 共享库加载顺序 LD_PRELOAD -> /etc/ld.so.preload -> DT_RPATH(编译指定) -> LD_LIBRARY_PATH ->...对于大多数对技术没有那么偏执的兄弟在这里可以结束了,上面内容作为LD_PRELOAD后门知识点的补充 LD_PRELOAD 劫持 PWD 为什么失败了 绝大多数看这个问题应该会很蒙,我简单介绍一下背景...,2020-07-05 我写了以下这篇文章 LD_PRELOAD 后门 | Linux 后门系列 在这篇文章的最后,我遗憾得告诉大家,劫持 whoami 命令很顺利,但是劫持 pwd 却失败,到最后都没有解决...,实际上我做了很多的尝试,问了一些人,也没有得到解决 为此呢,我去学习了 Linux C语言,Linux 汇编,Linux 链接装载等相关知识,终于在快一年的时候,我把这个问题解决了 它就像一座小山,挡在我前面

2K40

LD_PRELOAD 后门 | bypass disable_functions

LD_PRELOAD 后门 用途 主要是用于绕过 disable_functions ,本质上是加载顺序的问题, 动态链接库加载过程中会先加载 LD_PRELOAD 指向的变量,这样我们可以利用这个先加载来进行劫持正常的函数和命令...disable_functions 劫持命令调用函数的步骤: 在内部重写函数,将原有的函数覆盖 将原函数指针赋值给一个变量 触发重写的函数 在重写函数中执行原函数 照常返回正常值(保证命令的正常执行) 漏洞原理 Linux...ELF 共享库加载顺序: LD_PRELOAD -> /etc/ld.so.preload -> DT_RPATH(编译指定) -> LD_LIBRARY_PATH -> [/etc/ld.so.conf...export LD_PRELOAD=/test/hack.so 运行命令触发覆盖函数 vi 检查是否存在 LD_PRELOAD 后门的时候可以直接运行echo $LD_PRELOAD...0=LD_PRELOAD&1=/test/hack.so 因为在执行bash -c "export LD_PRELOAD=ifconfig"会执行里面的ifconfig命令然后把执行结果赋给LD_PRELOAD

80040

CTFHub:web-LD_PRELOAD-WP

逐一尝试,或许有漏网之鱼 mod_cgi 模式,尝试修改 .htaccess,调整请求访问路由,绕过 php.ini 中的任何限制(让特定扩展名的文件直接和php-cgi通信); 利用环境变量 LD_PRELOAD...大致步骤如下 生成一个我们的恶意动态链接库文件 利用putenv设置LD_PRELOAD为我们的恶意动态链接库文件的路径 配合php的某个函数去触发我们的恶意动态链接库文件 RCE并获取flag 这里面的某个函数需要在运行的时候能够启动子进程...LD_PRELOADLinux系统的一个环境变量,它可以影响程序的运行时的链接(Runtime linker),它允许你定义在程序运行前优先加载的动态链接库。... #include __attribute__ ((__constructor__)) void angel (void){ unsetenv("LD_PRELOAD...php putenv("LD_PRELOAD=/tmp/hack.so"); mail("", "", "", ""); ?> 然后去GET请求包含sunian.php url/?

13910

进阶 | 用 preload 预加载页面资源

preload 目前我们支持的浏览器主要为高版本 Chrome,所以可放心使用 preload 技术。...preload 将提升资源加载的优先级 使用 preload 前,在遇到资源依赖时进行加载: 使用 preload 后,不管资源是否使用都将提前加载: 可以看到,preload 的资源加载顺序将被提前...: 避免滥用 preload 使用 preload 后,Chrome 会有一个警告: 如上文所言,若不确定资源是必定会加载的,则不要错误使用 preload,以免本末倒置,给页面带来更沉重的负担。...避免混用 preload 和 prefetch preload 和 prefetch 混用的话,并不会复用资源,而是会重复加载。...with link rel='preload' Preload, Prefetch And Priorities in Chrome A Link: rel=preload Analysis From

1.1K20

使用 Preload&Prefetch 优化前端页面的资源加载

三、Preload 从上面的案例,我们体会到了浏览器预加载资源的强大能力。实际上,预加载是一个广义的概念,prefetch只是具体实现方式之一,本节我们介绍下另外一种预加载方式preload。...preload提示。...这些提示会被@vue/preload-webpack-plugin注入,并且可以通过chainWebpack的config.plugin('preload')进行修改和删除。...五、总结和踩坑 1、preload和prefetch的本质都是预加载,即先加载、后执行,加载与执行解耦。 2、preload和prefetch不会阻塞页面的onload。...4、不要滥用preload和prefetch,需要在合适的场景中使用。 5、preload的字体资源必须设置crossorigin属性,否则会导致重复加载。

1.2K60

使用 Preload&Prefetch 优化前端页面的资源加载「建议收藏」

三、Preload 从上面的案例,我们体会到了浏览器预加载资源的强大能力。实际上,预加载是一个广义的概念,prefetch只是具体实现方式之一,本节我们介绍下另外一种预加载方式preload。...preload提示。...这些提示会被@vue/preload-webpack-plugin注入,并且可以通过chainWebpack的config.plugin(‘preload’)进行修改和删除。...五、总结和踩坑 1、preload和prefetch的本质都是预加载,即先加载、后执行,加载与执行解耦。 2、preload和prefetch不会阻塞页面的onload。...4、不要滥用preload和prefetch,需要在合适的场景中使用。 5、preload的字体资源必须设置crossorigin属性,否则会导致重复加载。

1.1K31

Preload与Prefetch的区别以及webpack项目中如何优化

preload 与prefetch 的区别 preload 是一个声明式 fetch,可以强制浏览器在不阻塞 document 的 onload 事件的情况下请求资源。...使用方法: 通过 Link 标签进行创建: 在 HTTP 响应头中加上 preload...prefetch 预判加载与preload 使用方法是一样的 和的缓存行为 当资源被 preload 或者 prefetch 后,会从网络堆栈传输到 HTTP 缓存并进入渲染器的内存缓存。...对于 preload 来说,一旦页面关闭了,它就会立即停止 preload 获取资源,而对于 prefetch 资源,即使页面关闭,prefetch 发起的请求仍会进行不会中断。...preload 和 prefetch 的优先级、 preload 用 “as” 或者用 “type” 属性来表示他们请求资源的优先级(比如说 preload 使用 as=”style” 属性将获得最高的优先级

4.1K30
领券