CtfShow web入门——爆破21-28

1. web21

抓包发现用户名和密码被放到了Authorization: Basic YWRtaW46YWRtaW4=请求头里面,还被base64加密

这种爆破不太懂,看了一下官方提示里面:https://www.cnblogs.com/007NBqaq/p/13220297.html

使用的Burp Suite的Intruder的Custom iterator爆破模块。

BurpSuite 的 Custom Iterator(自定义迭代器) 模式可以灵活生成认证凭证组合,尤其适用于 Basic Auth 这种 用户名:密码 格式并经过 Base64 编码 的场景。

1.1. 选中payload:

1.2. 设置payloads,设置payload type为Custom interator;在设置Position1、2、3

1.3. 再设置payload processing

1.4. 取消payload encoding

1.5. 开始爆破,查看回包长度,即可得到flag

2. web22

题目提示:域名更新后,flag.ctf.show域名失效

如果不能访问http://flag.ctfer.com/index.php,直接交flag{ctf_show_web}吧 。

3. wbe23

error_reporting(0); include('flag.php'); if(isset($_GET['token'])){ $token = md5($_GET['token']); 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; } } }else{ highlight_file(__FILE__); } ?> 

3.1. 方法一:根据源码写了个脚本

import hashlib import itertools chars='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789' for length in range(1, 4): for combo in itertools.product(chars, repeat=length):.join(combo) md5_str = hashlib.md5(token.encode('utf-8')).hexdigest() c1,c14,c17 = md5_str[1], md5_str[14], md5_str[17] if c1 != c14 or c14 != c17: continue #print(f"Token: {token}, MD5: {md5_str}") try: x1 = int(c1) x2 = int(c14) x3 = int(c17) y = int(md5_str[31]) if x1 == 0: continue if ((x1 + x2 + x3)/x1) == y : print(f"Found matching token: {token}, MD5: {md5_str}") except: continue

然后跑出来一串子

应该都行吧,试了几个都可以

3.2. 方法二:使用BP

payload type设置成Brute forcer模式

然后开始跑,很多跑出来几个就暂停了

4. web24

 <?php error_reporting(0); include("flag.php"); if(isset($_GET['r'])){ $r = $_GET['r']; mt_srand(372619038); if(intval($r)===intval(mt_rand())){ echo $flag; } }else{ highlight_file(__FILE__); echo system('cat /proc/version'); } ?> Linux version 5.4.0-163-generic (buildd@lcy02-amd64-067) (gcc version 9.4.0 (Ubuntu 9.4.0-1ubuntu1~20.04.2)) #180-Ubuntu SMP Tue Sep 5 13:21:23 UTC 2023 Linux version 5.4.0-163-generic (buildd@lcy02-amd64-067) (gcc version 9.4.0 (Ubuntu 9.4.0-1ubuntu1~20.04.2)) #180-Ubuntu SMP Tue Sep 5 13:21:23 UTC 2023

4.1. mt_srand()是什么?

mt_srand(种子值)是 PHP 的伪随机数种子初始化函数

  • mt_rand()是 PHP 生成 “伪随机数” 的函数,但它的随机序列由 “种子” 决定
  • 只要给mt_srand()传入固定的种子值,后续mt_rand()生成的随机数序列就是完全固定、可预测的(伪随机的核心特点)

4.2. 解题突破口(核心利用点)

因为mt_srand(372619038)用了固定种子,所以mt_rand()生成的第一个随机数是固定的(伪随机数的可预测性)。

我们只需要计算 “种子 372619038 对应的第一个 mt_rand () 结果”,把这个数作为r的参数传入,就能满足条件拿到flag

写个脚本运行拿到第一次生成的随机数

<?php mt_srand(372619038); // 固定种子 echo "第一次调用mt_rand():" . mt_rand() . "\n"; echo "第二次调用mt_rand():" . mt_rand() . "\n"; echo "第三次调用mt_rand():" . mt_rand() . "\n"; ?>

5. web25

 <?php error_reporting(0); include("flag.php"); if(isset($_GET['r'])){ $r = $_GET['r']; mt_srand(hexdec(substr(md5($flag), 0,8))); #1-mt_rand()=-1988627018 #mt_rand()=1988627019 $rand = intval($r)-intval(mt_rand()); #$rand = 1988627019 if((!$rand)){ if($_COOKIE['token']==(mt_rand()+mt_rand())){ echo $flag; } }else{ echo $rand; } }else{ highlight_file(__FILE__); echo system('cat /proc/version'); } Linux version 5.4.0-163-generic (buildd@lcy02-amd64-067) (gcc version 9.4.0 (Ubuntu 9.4.0-1ubuntu1~20.04.2)) #180-Ubuntu SMP Tue Sep 5 13:21:23 UTC 2023 Linux version 5.4.0-163-generic (buildd@lcy02-amd64-067) (gcc version 9.4.0 (Ubuntu 9.4.0-1ubuntu1~20.04.2)) #180-Ubuntu SMP Tue Sep 5 13:21:23 UTC 2023

先审一遍代码:$rand = intval($r)-intval(mt_rand());

传个r=0,倒推出来第一次生成的mt_rand()伪随机数:1988627019

上网搜了一下,发现有个php_mt_seed工具能倒推出来随机数的种子值(https://www.openwall.com/php_mt_seed/)用Linux系统比较好执行。

5.1.1. 下载导入Linux系统

5.1.2. tar -zxvf filename解压

5.1.3. cd进该目录

5.1.4. chmod +x php_mt_seed.c赋可执行权限

5.1.5. 输入:make

5.1.6. 输入,得到种子

查看版本可知,这里我们选php 7.1.0+的

seed = 0x0ac64537 = 180766007 (PHP 7.1.0+)

seed = 0x2a0d8bda = 705530842 (PHP 7.1.0+)

seed = 0x2bc4c8c5 = 734316741 (PHP 7.1.0+)

seed = 0x967716e2 = 2524387042 (PHP 7.1.0+)

seed = 0xe37f57b9 = 3816773561 (PHP 5.2.1 to 7.0.x; HHVM)

seed = 0xe37f57b9 = 3816773561 (PHP 7.1.0+)

测试一下

但是不知道是哪个,用这个脚本试试吧,我是测试到了第三个才行的

<?php $seed =[180766007,705530842,734316741,2524387042,3816773561,3816773561]; for ($i = 0; $i < 5; $i++) { mt_srand($seed[$i]); mt_rand(); $token[$i] =intval(mt_rand())+intval(mt_rand()); echo "Token:".$token[$i]."\n"; } ?>

6. web26

function check(){ // 1. 定义名为check的函数,调用它就会执行里面的AJAX请求 $.ajax({ // 2. jQuery的AJAX方法,发起异步HTTP请求(不用刷新页面) url:'checkdb.php', // 3. 请求的后端接口地址:checkdb.php type: 'POST', // 4. 请求方式:POST(参数在请求体里,比GET安全) dataType:'json', // 5. 关键:告诉jQuery,期望后端返回【JSON格式】的响应 data:{ // 6. 要发送给后端的参数(键值对格式,不是JSON!) 'a':$('#a').val(), // 取页面上id="a"的输入框的内容,键名a 'p':$('#p').val(), // 取id="p"输入框的内容,键名p 'd':$('#d').val(), // 取id="d"输入框的内容,键名d 'u':$('#u').val(), // 取id="u"输入框的内容,键名u 'pass':$('#pass').val() // 取id="pass"输入框的内容,键名pass }, success:function(data){ // 7. 请求成功时执行的函数 alert(data['msg']); // 弹出后端返回的JSON里的msg字段内容 }, error:function(data){ // 8. 请求失败时执行的函数 alert(data['msg']); // 尝试弹出msg(失败时data结构不同,这里其实不太对) } }); }

直接抓包: 后端返回的内容是JSON 格式!!!不需要前端传JSON格式

7. web27

function check(){ $.ajax({ url:'checkdb.php', type: 'POST', dataType:'json', data:{ 'a':$('#a').val(), 'p':$('#p').val() }, success:function(data){ alert(data['msg']); }, error:function(data){ alert(data['msg']); } }); } 

下载附件后,从第一个开始爆破身份证号

得到该学生的信息,进行登录后,得到flag

高先伊 621022199002015237 02015237

8. web28

扫了一波没啥思路,看了大佬的wp说是爆破目录

要是爆破跑一半,不行了可以试试把redirections选成always

Read more

ComfyUI是什么?当AI绘画遇上“连连看”,专业创作原来可以如此简单!

目录 一、开篇明义:什么是ComfyUI? 二、核心设计哲学:为什么选择节点式工作流? 1. 完全透明化的生成过程 2. 可保存、可分享、可复用的工作流 3. 精细到极致的参数控制 三、ComfyUI技术架构剖析 1.核心组件详解 2.性能优势解析 四、实际应用场景:谁需要ComfyUI? 1. AI艺术创作者 2. 产品设计与原型开发 3. 教育与研究 4. 商业内容生产 用流程图玩转Stable Diffusion,揭开AI绘画的神秘面纱 一、开篇明义:什么是ComfyUI? 如果你曾对AI绘画感到好奇,或已经尝试过Midjourney、Stable Diffusion WebUI等工具,那么ComfyUI将为你打开一扇全新的门。这不是又一个“输入文字出图片”的简单工具,而是一个可视化节点编辑器,专门为Stable Diffusion设计。

Kook Zimage真实幻想Turbo应用探索:AR滤镜素材/VR场景幻想贴图生成

Kook Zimage真实幻想Turbo应用探索:AR滤镜素材/VR场景幻想贴图生成 1. 项目简介 Kook Zimage真实幻想Turbo是一款专为创意设计领域打造的AI图像生成工具,它基于先进的Z-Image-Turbo技术架构,专门针对幻想风格图像生成进行了深度优化。这个工具能够帮助设计师、创作者快速生成高质量的AR滤镜素材和VR场景贴图,大大提升了创意工作的效率和质量。 与传统的图像生成工具不同,Kook Zimage真实幻想Turbo在保持极速生成的同时,特别强化了幻想风格的表达能力和画面细节。无论是梦幻般的光影效果、奇幻的人物造型,还是超现实的场景构建,都能通过简单的文字描述快速实现。 这个工具最大的优势在于它的易用性和专业性平衡。你不需要深厚的技术背景,也不需要昂贵的硬件设备,就能创作出专业级的幻想风格图像作品。无论是个人创作者还是专业设计团队,都能从中获得巨大的价值。 2. 核心功能特点 2.1 极速生成能力 Kook Zimage真实幻想Turbo继承了Z-Image-Turbo架构的快速生成特性,通常只需要10-15个生成步骤就能产出高质量图像。

ROS1从入门到精通 12:导航与路径规划(让机器人自主导航)

【ROS1从入门到精通】第12篇:导航与路径规划(让机器人自主导航) 🎯 本文目标:深入学习ROS导航栈(Navigation Stack),掌握move_base框架、全局路径规划、局部路径规划、代价地图、恢复行为等核心概念,能够配置和调试完整的自主导航系统,实现机器人的智能移动。 📑 目录 1. ROS导航栈概述 2. move_base框架 3. 代价地图(Costmap) 4. 全局路径规划 5. 局部路径规划 6. 恢复行为 7. 导航配置与调优 8. 导航目标发送 9. 多机器人导航 10. 实战案例:完整导航系统 11. 总结与最佳实践 1. ROS导航栈概述 1.1 什么是ROS导航栈? ROS导航栈是一个2D导航框架,提供了从当前位置到目标位置的路径规划和执行能力。它包括: