[ctfshow web入门] web23

前置知识

include:包含一个文件,也可以包含一些其他东西,后续用到再解析

substr:对字符串进行切片,第一个参数是字符串,第二第三个参数出从第a个索引开始切n个,索引从0开始计数。

例如:$a = substr("012345", 2, 3);$a === '234'

intval:其他类型转换为int类型,不可用于array和object。第一个参数是需要转换的值,第二个可选参数可以制定进制,默认是十进制。

例如:intval("a") ==> 0,intval("123a") ⇒ 123,后续的非数字将被截断,Intval与 ==搭配可能会出现漏洞,后续用到再说。

信息收集

php 复制代码
    if(substr($token, 1,1)===substr($token, 14,1) && substr($token, 14,1) ===substr($token, 17,1)){
        if((intval(substr($token, 1,1))+intval(substr($token, 14,1))+substr($token, 17,1))/substr($token, 1,1)===intval(substr($token, 31,1))){
            echo $flag;
        }
    }

关键在于这里,只要按照它的要求跑出这个token即可。所以我们自己构造代码,随机生成md5,检查md5是否满足要求,若满足要求,输出md5对应的字符串。

解题:

为什么是自己跑md5,而不是爆破网站,因为在现实情况下,频繁访问网站可能会被ban掉IP。还有一个原因是,爆破网站比本地爆破慢太多了

我只会python,所以用python写的,如果用php可以直接抄写它的判断语句,不用翻译

python 复制代码
import itertools
import hashlib
import string
def md5(s):
    if type(s) != bytes:
        s = bytes(s, encoding="utf-8")
    hash_md5 = hashlib.md5()
    hash_md5.update(s)
    return hash_md5.hexdigest()

def web23():
    dir = string.digits + string.ascii_uppercase + string.ascii_lowercase
    # 这里我不知道多少位能满足需求,所以写成变量,如果1-3位跑不出来,我可以跑更多位的
    for i in range(1, 4):
        for comb in itertools.combinations_with_replacement(dir, i):
            str_comb = "".join(comb)
            v_md5 = md5(str_comb)
            if v_md5[1] == v_md5[14] == v_md5[17]:
                try: # 除零异常,字符串无法转int异常,我懒得处理了,统统忽略就行了
                    if ((int(v_md5[1])+int(v_md5[14])+int(v_md5[17]))/int(v_md5[1])==int(v_md5[31])):
                        print(str_comb)
                        print(v_md5[1], v_md5[14], v_md5[17])
                except:
                    pass

if __name__ == '__main__':
    web23()

跑出来这些结果

shell 复制代码
3j
6Vh
AKh
JKh
Jik
SVi
UYg
ejt

输入url/?token=3j拿到flag

web22题目已弃用
web21    目录    web24

相关推荐
白帽黑客-晨哥1 分钟前
零基础转行网络安全需要学多久?
网络·安全·web安全·网络安全·零基础·就业·转行
河南互链数安22 分钟前
企业多类型项目验收:渗透测试核心指南
网络·安全·web安全
漏洞文库-Web安全26 分钟前
CTFHub XSS通关:XSS-过滤关键词 - 教程
前端·安全·web安全·okhttp·网络安全·ctf·xss
漏洞文库-Web安全1 小时前
CTFHub 信息泄露通关笔记9:Git泄露 Index - 指南
笔记·git·安全·web安全·elasticsearch·网络安全·ctf
重生之我在番茄自学网安拯救世界1 小时前
网络安全中级阶段学习笔记(六):网络安全 SSRF 漏洞学习笔记
笔记·学习·网络安全·ssrf
中云DDoS CC防护蔡蔡1 小时前
国外服务器延迟高怎么办
服务器·经验分享·http·网络安全·ddos
老赵聊算法、大模型备案1 小时前
新规解读|《公安机关网络空间安全监督检查办法(征求意见稿)》发布,AI与互联网企业需重点关注哪些合规义务?
人工智能·安全·web安全
pandarking2 小时前
[CTF]攻防世界:very_easy_sql(gopher)
数据库·sql·web安全·ctf
云计算练习生3 小时前
渗透测试行业术语扫盲(第五篇)—— 信息收集与扫描篇
网络安全·信息安全·渗透测试·扫描·信息收集·渗透测试术语·网络安全术语
一起学安全技术16 小时前
C11期作业14(06.14)
web安全·网络安全