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(一)Quartus II 13.1及modelsim与modelsim-altera安装教程及可能遇到的相关问题

FPGA(一)Quartus II 13.1及modelsim与modelsim-altera安装教程及可能遇到的相关问题

零.前言         在学习FPGA课程时,感觉学校机房电脑用起来不是很方便,想着在自己电脑上下载一个Quartus II 来进行 基于 vhdl 语言的FPGA开发。原以为是一件很简单的事情,没想到搜了全网文章发现几乎没有一个完整且详细的流程教学安装(也可能是我没搜到,,ԾㅂԾ,,)【视频b站上有,搞完才发现T.T】,因此想做一个纯小白式安装教程,将网上分享的几位大佬关于安装部分的流程都总结到一文当中,包括软件及软件配套仿真和芯片库的安装,让大家花最少的时间完成安装。相关文章链接在文末。 多图预警 一.Quartus安装 1.首先需要先去百度网盘下载相关资料 下载链接:百度网盘 请输入提取码 提取码:qomk  2.下载的是压缩包,解压后可以看到13个文件 先打开QuartusSetup-13.1.0.162.exe文件开始安装。 3.安装流程 (1)打开后点击next (2)选择第一个accept,再点击next (3)选择文件夹可以自定义安装的位置,尽量建立一个新的文件夹(

【优质开源项目】AIGC开源推荐-全球情报监控平台worldmonitor

【优质开源项目】AIGC开源推荐-全球情报监控平台worldmonitor

1.概述 World Monitor 是一个开源的实时情报/监测仪表盘,聚合多类数据源(新闻、地理/卫星、航运/空中、财经、威胁情报等),提供交互式地理视图、AI 摘要、事件聚合与报警,支持 Web / PWA / Tauri 桌面三种运行方式,并可通过变体(WORLD / TECH / FINANCE)切换功能集。 2. 总体技术架构(分层视角) 客户端层(Browser / PWA / Tauri desktop) * • React + TypeScript + Vite 构建。 * • 地图/可视化:deck.gl(WebGL 3D globe)、MapLibre GL、D3

【VSCode Copilot登录失败终极指南】:9大常见问题与高效解决方案

第一章:VSCode Copilot登录失败的典型表现 当使用 VSCode 中的 GitHub Copilot 插件时,用户在尝试登录过程中可能会遇到多种异常现象。这些表现不仅影响代码补全功能的正常使用,还可能干扰开发流程。以下是常见的登录失败典型表现。 认证窗口无法加载 部分用户在点击“Sign in to GitHub”后,浏览器或内置认证弹窗长时间停留在加载状态,最终显示空白页面或提示网络错误。这通常与本地网络策略、代理设置或防火墙规则有关。 登录成功但插件无响应 尽管认证流程显示已完成,Copilot 图标仍显示未登录状态,且不提供任何代码建议。此时可在命令面板(Ctrl+Shift+P)中执行以下命令检查状态: # 检查 Copilot 当前会话状态 Developer: Reload With Extensions Disabled # 重新启用后再次尝试 GitHub Copilot: Sign in to GitHub 错误提示信息汇总

如何部署本地 stable diffusion 本地使用大模型Z Image Turbo

🛠️ 部署 Stable Diffusion 详细步骤(以 Automatic1111 WebUI 为例) 1. 准备工作(系统和硬件要求) * 操作系统: Windows 10/11, macOS (Apple Silicon 芯片), 或 Linux。NVIDIA: 推荐使用 NVIDIA 显卡(RTX 系列为佳),显存 (VRAM) 最好在 8GB 或以上。这是 Windows 上运行 SD 性能最好的选择。 * 显卡 (GPU): * AMD: 也可以,但设置可能更复杂,且性能通常不如 NVIDIA。 * Apple Silicon (M系列芯片): 在 macOS 上性能优秀,