access偏移注入


记录总结偏移注入的使用方法。

为什么要用偏移注入

偏移注入是access比较独有的一种注入手段,很有特点(人品。。)的注入方式,一般用于在猜出了表名但是没有猜出列名的情况下使用。

偏移注入的使用

  • 目前猜测出了表名,但是怎么都猜不出列名,使用联合查询法来进行偏移注入。
  • 接下来测出偏移量,其实这个偏移量就是admin这张表的列的个数。直接将22改成*号,测试是否回显正常,不正常就一直往前减,一直减少到回显正常为止。

    这里运气比较好,直接就爆出了密码(听说是随机的=。=但是不知道要怎么确认真实性),但是还没有用户名呢,那么接下来可以打乱顺序来重置爆出来的结果,这里可以使用下列方法来进行完成。

    从图中可以看出已经爆出了用户名为admin了。
  • 简单说下语句,UNION SELECT 1,2,3,* from (admin as a inner join admin as b on a.id=b.id),首先为什么从union select 1,2,3,4,5,6,* from变成了1,2,3,*呢,是这样推导出来的。
    1. order by 9代表有9个回显点
    2. 1,2,3,4,5,6,*代表admin表的字段数只有3个
    3. admin表变成了(admin as a inner join admin as b on a.id=b.id),这里是将admin重命名为了a和b两张表,然后通过inner join 将a表和b表的id相同字段展示出来,a表和b表本来都是admin表,所以id肯定都是相同的(这里要提醒一下,id这个字段可以换成其它字段,但是一定得存在,一般admin表中都存在id字段的),这样做的目的就是可以打乱顺序来爆出其它字段
    4. 但是由于增加了一张表,所以字段数得再减少一个*号的长度,所以就从6变成了3。
  • 但是这样爆东西非常有随机性,如果表的字段比较多,而这个显示位又比较少的话,是很有可能爆不出自己想要的东西的。我们接下来介绍一些其它的技巧。

偏移注入的进阶

  • 我们来看一下这样的一个站点,同样通过order by 和union select找到了表为admin,但是还是扫不出列名,这次回显点有22个。
  • 一次一次的测试admin的列的个数,最终长度为6,而且这次什么都没爆出来。
  • 开始偏移注入,爆出的结果却是时间。
  • 此时可以增加a.id或者b.id或者a.id和b.id一起加上去来打乱随机的顺序,时间确实换了,但是又不是我们想要的,这只是一个数字,可能是id值之类的吧。
  • 别灰心,继续来看,骚东西来了,查看网页的源代码,会有隐藏的惊喜。。。

    我们发现这里有隐藏起来的回显点,爆出来了用户名为admin,但是还没有密码。
  • 增加表的个数,修改代码,UNION SELECT 1,2,3,4,* from ((admin as a inner join admin as b on a.id=b.id) inner join admin as c on a.id=c.id),查看源代码,成功拿到用户名和密码了。

总结

如果回显点足够多,要查的表的字段足够少,那么也可以认为偏移注入的成功率是100%,不过话说回来,这玩意还是得碰运气,有些技巧只是可以提高成功率而已。
  • 8
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值