第1关直接ssh连接,获得密码NH2SXQwcBdpmTEzi3bvBHMM9H66vVXjL,用这个密码连接第2关
第2关,连接之后查看
data:image/s3,"s3://crabby-images/a1873/a1873121fa4948d33189a455d8e6baa10a755b46" alt=""
存在特殊字符的文件
data:image/s3,"s3://crabby-images/7eeae/7eeaec16c18dbd1acb42b571b5b93df40ba34b01" alt=""
因为使用 - 作为参数是指 STDIN/STDOUT 即 dev/stdin 或 dev/stdout 。所以如果你想打开这种类型的文件,你必须指定文件的完整位置,例如作为 ./- 。例如。 ,如果您想查看该文件中的内容,请使用 cat ./-
获得密码:rRGizSaX8Mk1RTb1CNQoXTcYZWU6lgzi,使用该密码连接第3关
data:image/s3,"s3://crabby-images/6d984/6d984859a476529f72906b34dec24d7447011229" alt=""
发现存在空格文件名,引号引起来就行
data:image/s3,"s3://crabby-images/2798d/2798d0fcc76a29f03f56e78a04fca65d88a0aef1" alt=""
获得密码:aBZ0W5EmUfAf7kHTQeOwd8bauFJ2lAiG,连接第4关
data:image/s3,"s3://crabby-images/03e8f/03e8fefbf997aca5354688251c884e3af774b156" alt=""
这一关用ls -al命令查看隐藏文件,然后打开就行,获得密码:2EW7BBsr6aMMoJ2HjW067dm8EgX26xNe,连接第5关
第5关是这样的
data:image/s3,"s3://crabby-images/2a302/2a302e5c2faa8c48c36f48e956a0152480768611" alt=""
文件一个个打开,在第8个文件
data:image/s3,"s3://crabby-images/61e81/61e81594ad91140fedaf4fe106f8db6cc48d027d" alt=""
获得密码:lrIWWI6bB37kxfiCQZqUdOIYfr6eEeqR,连接第6关
data:image/s3,"s3://crabby-images/7f1b7/7f1b77396a9d4e07cba84f8573faeec01731932e" alt=""
可以看到有很多的文件夹,根据题目的提示该文件是个1033字节大小的文件
data:image/s3,"s3://crabby-images/9641c/9641c438cdf4ac23e15ceca2d7eb1192a56dd5c2" alt=""
这里使用到命令find -type f -size 1033c ! -executable
find
命令是在Unix和类Unix系统中用于搜索文件和目录的强大工具。以下是一些常用的find
命令选项:
-
路径和条件:
-name pattern
: 根据文件名进行搜索,可以使用通配符。-iname pattern
: 类似于-name
,但是不区分大小写。-path pattern
: 根据完整路径进行搜索,可以使用通配符。
-
类型判定:
-type type
: 根据文件类型进行搜索,其中type
可以是f
(普通文件)、d
(目录)、l
(符号链接)等。
-
时间相关:
-mtime n
: 根据文件修改时间进行搜索,n
表示天数。-atime n
: 根据文件访问时间进行搜索。-ctime n
: 根据文件状态改变时间进行搜索。
-
大小相关:
-size n
: 根据文件大小进行搜索,n
可以是正数(大于n),负数(小于n),或者零(等于n)。
-
执行操作:
-exec command {} \;
: 对每个找到的文件执行指定的命令。-exec command {} +
: 类似于\;
,但多个文件一次性传递给一次命令。
-
逻辑操作:
-and
,-or
,-not
: 用于组合多个条件。
! -executable是排除可执行文件的意思
获得密码:P4L4vucdmLnm8I7Vl7jG1ApGSfjYKqJU,连接第7关
第7关也是查找命令的运用,使用find . -group bandit6 -user bandit7进行查找,因为题目提示了
The password for the next level is stored somewhere on the server and has all of the following properties:
- owned by user bandit7
- owned by group bandit6
- 33 bytes in size
data:image/s3,"s3://crabby-images/793ff/793ff74dd09fed1751985b524d34f5623ee1242e" alt=""
然后打开该文件就行,获得密码:z7WtoNQU2XfjmMtWA8u5rN4vzqu4v99S,连接第8关
data:image/s3,"s3://crabby-images/0fd44/0fd4461696075685f6b744ada3e93ca25681b6d4" alt=""
连接后有一个data.txt文件,打开后是一堆数据,题目有提示:The password for the next level is stored in the file data.txt next to the word millionth
data:image/s3,"s3://crabby-images/905e1/905e13869118f68480f5d8b371ca0f1cfe0924ef" alt=""
直接用grep搜索即可得到密码:TESKZC0XvTetK0S9xNwm25STk5iWrBvP,连接第9关
题目提示为:The password for the next level is stored in the file data.txt and is the only line of text that occurs only once (下一级的密码存储在文件data.txt中 ,并且是唯一只出现一次的文本行)
data:image/s3,"s3://crabby-images/f10d3/f10d3527c43638d89935cfd199904bb890575c07" alt=""
这里使用了命令:sort data.txt |uniq -c
sort命令:这会按字母顺序对文件 filename 的内容进行排序,并将结果输出到标准输出。
uniq命令:uniq filename 这会从文件 filename 中删除相邻的重复行,只保留一个副本。 计算重复行的数量
uniq -c filename 使用 -c 选项,uniq 会显示每行在输入文件中出现的次数。
可获得密码:EN632PlfYiZbn3PhVK3XOGSlNInNE00t,连接第10关
第10关提示:The password for the next level is stored in the file data.txt in one of the few human-readable strings, preceded by several '=' characters.(下一级的密码存储在文件data.txt中,位于少数几个人类可读的字符串之一中,以几个"="字符开头。)
我们先来试着cat一下这个文件
data:image/s3,"s3://crabby-images/bab03/bab03a8cbe01c821e167c80003f3f188ac1937f0" alt=""
发现是一堆乱码,这里可以用strings命令查找可以读的字符串
data:image/s3,"s3://crabby-images/3763f/3763fce8973f0ecb5e916de404939b7ba18a7898" alt=""
得到密码:G7w8LIi6J3kTb8A7j9LgrywtEUlyyp6s