文件描述符(File Descriptor, FD)详解及利用方法

news2025/4/19 15:54:55

文件描述符(FD)是 Linux/Unix 系统中用于访问文件、管道、套接字等 I/O 资源的整数标识符。每个进程默认打开 3 个标准文件描述符:

FD名称默认绑定设备用途
0stdin键盘标准输入(读取数据)
1stdout终端屏幕标准输出(打印数据)
2stderr终端屏幕标准错误(打印错误)

一、文件描述符如何工作?

Linux 内核为每个进程维护一个 文件描述符表(File Descriptor Table),通过 FD 索引访问对应的文件或设备:

进程A
├── FD 0 → stdin(键盘)
├── FD 1 → stdout(终端)
├── FD 2 → stderr(终端)
├── FD 3 → /etc/passwd(打开的文件)
└── FD 4 → socket(网络连接)

 二、如何查看进程的文件描述符?

方法 1:ls -l /proc/<PID>/fd

ls -l /proc/$$/fd  # 查看当前 shell 的 FD

输出示例:

lrwx------ 1 user user 64 Jan 1 00:00 0 → /dev/pts/0 (stdin)
lrwx------ 1 user user 64 Jan 1 00:00 1 → /dev/pts/0 (stdout)
lrwx------ 1 user user 64 Jan 1 00:00 2 → /dev/pts/0 (stderr)

方法 2:lsof -p <PID>

lsof -p $$  # 查看当前进程的所有 FD

三、文件描述符的利用方法

文件描述符在 系统安全、漏洞利用(PWN)、权限提升 中有重要作用。

1. 文件描述符劫持(FD Hijacking)

场景:某些程序以高权限运行时,可能意外泄漏敏感 FD(如打开 /etc/shadow)。
利用方法

# 假设某个 SUID 程序意外泄漏了 FD 3 指向 /etc/shadow
cat /proc/<PID>/fd/3  # 尝试读取

2. 重定向敏感数据(Bash 重定向)

场景:通过 exec 修改进程的 FD,实现持久化重定向。
示例

exec 3>/tmp/stolen_data.txt  # 打开 FD 3 并绑定到文件
echo "Sensitive Data" >&3   # 写入 FD 3
exec 3>&-                   # 关闭 FD 3

3. 绕过过滤(如 PWN 题目中的 1>&2

场景:程序可能过滤 stdout,但 stderr 仍然可用。
利用方法

# 在漏洞利用中,让数据从 stderr 泄露
p.sendline(b"exec 1>&2")  # 让 stdout 走 stderr
p.sendline(b"cat flag")   # 结果从 stderr 输出

4. 文件描述符注入(FD Injection)

场景:通过 ptrace/proc/<PID>/fd 向进程注入 FD。
示例

# 假设目标进程 PID=1234,我们想让它的 FD 3 指向 /etc/passwd
ln -s /etc/passwd /proc/1234/fd/3  # 符号链接攻击(需权限)

5. 特权文件访问(通过泄漏的 FD)

场景:某些 SUID 程序可能意外继承高权限 FD。
示例

# 如果某个 SUID-root 程序打开了 /etc/shadow 并泄漏 FD
cat /proc/<PID>/fd/3  # 可能读到 shadow 文件

四、防御措施

  • 最小权限原则:程序运行时关闭不必要的 FD。
  • close() 未使用的 FD:防止泄漏。
  • O_CLOEXEC 标志exec 时自动关闭 FD。
  • 限制 /proc/<PID>/fd 访问:防止低权限用户窥探。

五、总结

技术用途示例
FD 劫持读取进程泄漏的敏感 FDcat /proc/1234/fd/3
重定向绕过让数据从 stderr 泄露exec 1>&2; cat flag
FD 注入通过 /proc 修改目标进程的 FDln -s /etc/passwd /proc/1234/fd/3
特权 FD 利用通过 SUID 程序泄漏的 FD 读敏感文件cat /proc/<SUID-PID>/fd/x

文件描述符是 Linux 系统安全的关键部分,理解其机制可以用于 漏洞利用、权限提升、数据泄露,同时也是 防御敏感数据泄漏 的重要知识点。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2337204.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ArcGIS Desktop使用入门(四)——9版本与10版本区别

系列文章目录 ArcGIS Desktop使用入门&#xff08;一&#xff09;软件初认识 ArcGIS Desktop使用入门&#xff08;二&#xff09;常用工具条——标准工具 ArcGIS Desktop使用入门&#xff08;二&#xff09;常用工具条——编辑器 ArcGIS Desktop使用入门&#xff08;二&#x…

R语言之环境清理

有时候 R 环境中残留的变量可能会导致警告&#xff0c;可以尝试清理工作空间并重新加载数据。 警告信息: In mget(objectNames, envir ns, inherits TRUE) : 重新评估被中断的许诺 # 观察前6行 head(iris)# 观察数据结构 str(iris)# 探知数据的极值和分位数&#xff0c;以及…

javaSE————网络编程套接字

网络编程套接字~~~~~ 好久没更新啦&#xff0c;蓝桥杯爆掉了&#xff0c;从今天开始爆更嗷&#xff1b; 1&#xff0c;网络编程基础 为啥要有网络编程呢&#xff0c;我们进行网络通信就是为了获取丰富的网络资源&#xff0c;说实话真的很神奇&#xff0c;想想我们躺在床上&a…

FreeRTOS二值信号量详解与实战教程

FreeRTOS二值信号量详解与实战教程 &#x1f4da; 作者推荐&#xff1a;想系统学习FreeRTOS嵌入式开发&#xff1f;请访问我的FreeRTOS开源学习库&#xff0c;内含从入门到精通的完整教程和实例代码&#xff01; 1. 二值信号量核心概念解析 二值信号量(Binary Semaphore)是Fre…

赛灵思 XCVU440-2FLGA2892E XilinxFPGA Virtex UltraScale

XCVU440-2FLGA2892E 属于 Xilinx Virtex UltraScale 系列&#xff0c;是面向高端应用的旗舰 FPGA 器件。该系列产品以出色的高并行处理能力、丰富的逻辑资源和高速互联能力闻名&#xff0c;广泛用于 高性能计算、数字信号处理等对计算能力和带宽要求极高的场景。采用先进的 20n…

Spring Cloud Alibaba微服务-微服务介绍和搭建

1. 课程介绍 单体服务中有订单&#xff0c;用户&#xff0c;库存&#xff0c; 两个缺陷&#xff1a; a. 是以应用的维度进行负载均衡&#xff0c;资源占用大 b. 当其中一个模块宕机&#xff0c;整个应用就不能用了&#xff1b; nacos&#xff1b;ribbon&#xff0c;loadBa…

KALI安装JAVA8和切换JDK版本

一、安装JDK1.8 1、直接使用下面的地址下载java 1.8&#xff1a; https://repo.huaweicloud.com/java/jdk/8u202-b08/jdk-8u202-linux-x64.tar.gz 2、建立目录&#xff0c;将下载的jdk的安装包复制过去并进行解压 sudo mkdir -p /usr/local/java cp jdk-8u202-linux-x64.t…

今日行情明日机会——20250417

指数目前在区间内缩量震荡 2025年4月17日涨停主要行业方向分析 一、核心主线方向 化工&#xff08;产能优化涨价预期&#xff09; • 涨停家数&#xff1a;11家&#xff08;最强方向&#xff09;。 • 代表标的&#xff1a; ◦ 红宝丽&#xff08;2连板&#xff09;&#xff…

一篇讲完自动化测试基础-Python【万字详细讲解】12

✨博客主页&#xff1a; https://blog.csdn.net/m0_63815035?typeblog &#x1f497;《博客内容》&#xff1a;.NET、Java.测试开发、Python、Android、Go、Node、Android前端小程序等相关领域知识 &#x1f4e2;博客专栏&#xff1a; https://blog.csdn.net/m0_63815035/cat…

极限编程(XP)简介及其价值观与最佳实践

目录 一、什么是极限编程&#xff08;XP&#xff09;二、极限编程的核心价值观1. 沟通2. 简单3. 反馈4. 勇气 三、极限编程的12个最佳实践1. 结对编程2. 40小时工作制3. 简单设计4. 代码规范5. 测试驱动开发&#xff08;TDD&#xff09;6. 系统隐喻7. 持续集成8. 重构9. 客户在…

四层板的蛇形走线技巧:原理、策略与应用

在四层板的设计过程中&#xff0c;蛇形走线是一种常见且重要的布线方式。它能够满足特定的设计需求&#xff0c;如调整信号线长度、实现等长布线等&#xff0c;但如果使用不当&#xff0c;也可能会带来一些负面影响&#xff0c;如增加信号衰减、引入电磁干扰等。以下将详细探讨…

面向对象—有理数类的设计

目录 1.代码呈现 1.1编写toString、equals方法 1.2测试代码 1.3有理数类的代码 2.论述题 3.有理类设计 1.代码呈现 1.1编写toString、equals方法 (1)toString方法 Overridepublic String toString(){if(this.v20){return "Undefined";}return this.v1 "/…

408数据结构绪论刷题001

答案&#xff1a;D 解析&#xff1a; • A选项&#xff1a;数据元素是组成数据对象的基本单位 &#xff0c;它只是数据的基本个体&#xff0c;不能完整定义数据结构&#xff0c;所以A选项错误。 • B选项&#xff1a;数据对象是性质相同的数据元素的集合&#xff0c;仅仅描述…

Leetcode 3359. 查找最大元素不超过 K 的有序子矩阵【Plus题】

1.题目基本信息 1.1.题目描述 给定一个大小为 m x n 的二维矩阵 grid。同时给定一个 非负整数 k。 返回满足下列条件的 grid 的子矩阵数量&#xff1a; 子矩阵中最大的元素 小于等于 k。 子矩阵的每一行都以 非递增 顺序排序。 矩阵的子矩阵 (x1, y1, x2, y2) 是通过选择…

文件系统 软硬连接

&#x1f33b;个人主页&#xff1a;路飞雪吖~ &#x1f320;专栏&#xff1a;Linux 目录 一、理解文件系统 &#x1f320;磁盘结构 二、软硬连接 &#x1f31f;软硬链接 &#x1f320;软链接&#xff1a; &#x1f320;硬链接&#xff1a; &#x1f31f;理解软硬链接的应…

计算机视觉——JPEG AI 标准发布了图像压缩新突破与数字图像取证的挑战及应对策略

概述 今年2月&#xff0c;经过多年旨在利用机器学习技术开发一种更小、更易于传输和存储且不损失感知质量的图像编解码器的研究后&#xff0c;JPEG AI国际标准正式发布。 来自JPEG AI官方发布流&#xff0c;峰值信噪比&#xff08;PSNR&#xff09;与JPEG AI的机器学习增强方法…

Oracle 19c部署之数据库软件安装(二)

在完成了Oracle Linux 9的初始化配置之后&#xff0c;我们准备安装Oracle 19c数据库软件。 Oracle数据库支持两种主要的安装方式&#xff1a;图形化安装和静默安装。这两种方法各有优缺点&#xff0c;选择哪种取决于你的具体需求、环境配置以及个人偏好。 图形化安装 图形化安…

在Vmware15(虚拟机免费) 中安装纯净win10详细过程

一、软件备选 1. VMware15.5.1 网盘下载地址 链接: https://pan.baidu.com/s/1y6GLJ2MG-1tomWblt3otsg?pwdim8e 提取码: im8e 2. windows镜像下载 去官网下载ios包 链接&#xff1a;https://www.microsoft.com/zh-cn/software-download/windows10 二、在VMware15.5.1下安装w…

[Spark]深入解密Spark SQL源码:Catalyst框架如何优雅地解析你的SQL

本文内容组织形式 总结具体例子执行语句解析层优化层物理计划层执行层 猜你喜欢PS 总结 先写个总结&#xff0c;接下来会分别产出各个部分的源码解析&#xff0c;Spark SQL主要分为以下五个执行部分。 具体例子 接下来举个具体的例子来说明 执行语句 SELECT name, age FR…

基于Flask的漏洞挖掘知识库系统设计与实现

基于Flask的漏洞挖掘知识库系统设计与实现 一、系统架构设计 1.1 整体架构 本系统采用经典的三层Web架构&#xff0c;通过Mermaid图展示的组件交互流程清晰呈现了以下核心模块&#xff1a; 前端展示层&#xff1a;基于Bootstrap5构建响应式界面业务逻辑层&#xff1a;Flask…