站库分离渗透思路技巧总结

您所在的位置:网站首页 网站数据库渗透 站库分离渗透思路技巧总结

站库分离渗透思路技巧总结

2024-07-17 06:32| 来源: 网络整理| 查看: 265

前言

站库分离其实就是管理员将网站程序和数据库分别放在了不同的内网服务器上,这样看似提高了数据安全性,但是如果网站存在漏洞,攻击者还是有可能以Web或Data为入口访问到内网数据库服务器中的数据。

这种情况大多出现在内网环境,不过也有少部分管理员会使用公网数据库,如:自建公网数据库、Amazon/阿里/腾讯/华为RDS云数据库等,并设置允许连接该数据库的白名单IP地址。

正文

关于站库分离类型站点网上暂时没有找到总结性的文章,所以想尝试记录下关于站库分离类型站点的渗透思路。 对站库分离类型站点通常可以有两个渗透入口点: 1.web 网站 2.数据库 渗透思路其实也是比较常规。但是这里如果两个入口点无非两种路径。 1从 web 网站打入进而打站库分离的数据库,内网渗透 2从数据库打入进而打站库分离的 web 网站,内网渗透 根据不同的路径定制不同的渗透测试方案,下面记录一下流程和容易遇到的问题。

一、从 web 入口渗透

从 web 入口通常就是通过网站的各种漏洞来 getshell,比如文件上传、命令执行、代码执行、还有 SQL 注入写入一句话(into outfile、日志备份等)。 在获得 web 权限或者有诸如文件读取等漏洞时,我们还读数据库配置文件、对数据库内容分析、查找数据库备份,进而对数据库目标 ip 进行渗透,以便后续操作。

二、从数据库入口渗透

但是这里要说主要是外网暴露的数据库入口点弱口令;web 网站 SQL 注入。 从数据库入口渗透,同样主要是为了获取更大的权限,或者扩展我们的渗透成果,比如从数据库里可以得到一些密码信息,用户名等,在后续的内网渗透中可以很有效的帮助我们。 站点是站库分离的,数据库和 web 不在同一台服务器上,这时候不能写入一句话木马通过 web 去连,因为路径没有用。如果是从 web 端找到的 SQL 注入,那么可以通过以下这些方式去做信息收集、获取权限。

1.MYSQL

(1)定位 web 端 ip 地址 通过查询 information_schema 库中的 PROCESSLIST 可以查看当前 MYSQL 的连接情况。因为 web 应用会产生查询数据库操作,所以在回显出来的 host 字段中会带回目标的 ip:port。 select * from information_schema.PROCESSLIST;

在得到了 web 端的 ip 我们可以进而对 web 端进行渗透。 (2)load_file () 获取数据库所在服务器的敏感信息 如果没有 secure_file_priv 参数的限制(MySQL5.7 以下)我们还可以用 load_file() 函数对文件内容进行读取。 selectload_file('C:/test.txt');# 左斜杠 /

还可以获取网卡信息,比如读: /etc/udev/rules.d/70-persistent-net.rules获取网卡名称

/etc/sysconfig/network-scripts/ifcfg-网卡 静态IP DHCP的话 /var/lib/dhclient/dhclient--网卡.lease 2.MSSQL

(1) 判断是否站库分离 得到客户端主机名 selecthost_name(); 得到服务端主机名 select @@servername; 根据结果判断是否分离,结果一样就可能站库同服务器,结果不一样就是站库分离。 (2)存储过程执行命令 我们可以通过 MSSQL 的存储过程执行系统命令,可以尝试直接提升权限后渗透其他主机, 常用到的两个: 1XP_CMDSHELL 2SP_OACREATE 可以探测数据库服务器是否出网,通过执行 ping 或者 curl 看是否出网,通常遇到 MSSQL 我们直接就通过命令执行上线了。 同样是数据库,自然其中有一些敏感信息,为了进一步渗透,可以整理密码本或者其他信息。



【本文地址】


今日新闻


推荐新闻


    CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3