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

【FPGA/EDA】Quartus 18.0 软件安装及 ModelSim 环境配置

【FPGA/EDA】Quartus 18.0 软件安装及 ModelSim 环境配置

最近在上《EDA技术》这门电气专业的任选课,用到了Quartus 18.0和ModelSim软件工具进行波形图仿真,安装及配置教程十分曲折晦涩,故作此篇笔记用以记录。 软件资源及安装方法大纲由以下链接提供,以此为基准,本文只重点说明其中可能会遇到的问题及如何配置内部ModelSim波形图仿真工具。 在此感谢这位作者为大众提供了安装包资源及非常详细的安装教程!微信公众平台https://mp.weixin.qq.com/s?__biz=MzA4MjU4MTg2Ng==&mid=2247552337&idx=4&sn=c743d0f98c0b1be42fa7e92f9ea4f51a&chksm=9f81cd54a8f64442c4e7cc206e0907e56feee88ed8b30cb00ea7a72b797d4bbe406219c962d1&scene=178&cur_album_id=3421644748383879180&search_click_id=#rd  一、Quartus 18.0 软件安装中可能会遇到的问题

打造你的家庭 AI 助手(四):单 OpenClaw 配置多 Agent、多 QQ、飞书机器人

打造你的家庭 AI 助手(四):单 OpenClaw 配置多 Agent、多 QQ、飞书机器人

打造你的家庭 AI 助手(四):单 OpenClaw 配置多 Agent、多 QQ、飞书机器人 引言 OpenClaw 是一个强大的智能体(Agent)编排框架,它通过统一的架构让开发者可以轻松管理多个聊天机器人,并接入不同的即时通讯平台。在实际应用中,我们往往需要同时运行多个 QQ 机器人(例如个人助手、工作助手),甚至希望同一个智能体既能处理 QQ 消息,也能响应飞书消息。 本文将详细介绍如何在一个 OpenClaw 实例中配置多通道(QQ、飞书)、多 Agent 以及多 QQ 机器人账号,实现资源的高效利用和灵活的消息路由。特别地,我们将阐明飞书通道与 QQ 通道在绑定规则上的差异,避免常见的配置错误。 核心概念回顾 * Agent(智能体):拥有独立人格、记忆和技能的对话单元。每个

OpenClaw 新手指南:从零开始的 AI 机器人搭建完全攻略

OpenClaw 新手指南:从零开始的 AI 机器人搭建完全攻略 想随时随地通过微信、飞书、Telegram 等平台与 AI 助手对话?OpenClaw 帮你实现。 为什么选择 OpenClaw? OpenClaw 是一个开源的自托管 AI 网关,让你可以在自己服务器上运行一个 central hub,连接所有聊天平台到强大的 AI 模型(如 Claude、GPT、Pi、Kimi 等)。 核心优势: * ✅ 数据完全掌控(自托管,隐私安全) * ✅ 多平台统一管理(一个网关服务所有渠道) * ✅ 无代码扩展(通过技能系统) * ✅ 24/7 可用(开机自启动) * ✅ 日志和记忆(支持长期对话) 10个核心技巧详解 技巧 1:快速安装与配置 适用场景:

一文吃透SBUS协议:从原理到实战(无人机/航模/机器人适用)

在无人机、航模、机器人等精密控制领域,“稳定、快速、可靠”是控制信号传输的核心诉求。传统的PWM信号虽然简单直观,但存在通道数有限、抗干扰能力弱、布线复杂等痛点。而SBUS(Serial Bus)协议——由FUTABA公司专为遥控设备设计的串行数字通信协议,凭借单线传输多通道数据、抗干扰强、延迟低的核心优势,逐渐成为行业主流。 本文将从“是什么-怎么工作-协议细节-厂家产品-接口设计-代码实现-实战技巧-常见问题”八个维度,用最通俗的语言+大量对比表格,全面拆解SBUS协议。无论你是刚入门的电子爱好者,还是需要落地项目的工程师,都能从本文中找到所需的实用信息。 一、SBUS协议基础认知:核心定位与优势对比 在深入技术细节前,我们先通过对比和基础定义,快速建立对SBUS的认知。很多人会把SBUS和常见的UART、PWM等混淆,这里先明确其核心定位:SBUS是基于反向电平UART的“应用层控制协议”,专门用于遥控器与接收机、接收机与飞控/执行器之间的控制信号传输。 1.1 为什么需要SBUS?传统方案的痛点 在SBUS出现之前,航模和早期无人机主要使用PWM或PPM协议传输控