news 2026/6/21 11:43:56

[GWCTF 2019]枯燥的抽奖

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[GWCTF 2019]枯燥的抽奖

启动环境

检查发现源码

通过查找mt_rand函数资料,PHP的mt_rand函数作为一个随机数生成工具在程序中被广泛使用,但是大家都忽略了一个事实,mt_rand生成的随机数不是一个真正的随机数,而是一个伪随机数,不能应用于生成安全令牌、核心加解密key等等,所以很多知名程序都出现过对mt_rand函数的错误使用而导致的安全问题。

可以根据已经给出的部分随机数,利用工具找出seed(种子),然后得到完整的随机数。

上网寻找了下载php_mt_seed工具和使用方法

php_mt_seed是一个破解mt_rand函数seed的工具,在最简单的调用模式下,它能通过mt_rand第一次输出的值寻找mt_rand的seed,在更高级的模式中它能匹配不是第一次输出的和不明确具体输出的情况。

下载链接:php_mt_seed - PHP mt_rand() seed cracker

可以通过已经知道的几个字符去反推mt_rand()

python代码

str1='abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ' str2='6aZVpCGRLU' res='' for i in range(len(str2)): for j in range(len(str1)): if str2[i] == str1[j]: res+=str(j)+' '+str(j)+' '+'0'+' '+str(len(str1)-1)+' ' break print(res)

运行得到

使用php_mt_seed工具

得到种子345828701

计算整个字符串的代码

<?php
mt_srand(种子);
$str_long1 = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
$str='';
$len1=20;
for ( $i = 0; $i < $len1; $i++ ){
$str.=substr($str_long1, mt_rand(0, strlen($str_long1) - 1), 1);
}
echo $str;

提交得到flag

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 9:21:26

57、深入解析文件系统特性与Solaris内核框架

深入解析文件系统特性与Solaris内核框架 1. 文件系统概述 在现代计算机系统中,文件系统起着至关重要的作用,它负责数据的存储、组织和管理。下面将介绍一些常见的文件系统特性。 1.1 稀疏文件 某些文件系统允许在不分配磁盘块的情况下创建文件。例如,你可以通过打开一个…

作者头像 李华
网站建设 2026/6/15 7:36:25

MSF框架全解析:白帽子的实战指南与高级技巧

MSF框架全解析&#xff1a;白帽子的实战指南与高级技巧 一、MSF核心架构解析 1.1 什么是Metasploit Framework&#xff08;MSF&#xff09;&#xff1f; Metasploit Framework是一款开源渗透测试框架&#xff0c;相当于白帽子的“瑞士军刀”。它提供了完整的漏洞研究、开发和利…

作者头像 李华
网站建设 2026/6/18 22:52:52

突破语音合成边界:微软VibeVoice-1.5B技术深度剖析与实践指南

突破语音合成边界&#xff1a;微软VibeVoice-1.5B技术深度剖析与实践指南 【免费下载链接】VibeVoice-1.5B 项目地址: https://ai.gitcode.com/hf_mirrors/microsoft/VibeVoice-1.5B 在语音合成技术领域&#xff0c;传统文本转语音&#xff08;TTS&#xff09;系统长期…

作者头像 李华
网站建设 2026/6/20 19:45:56

10、MySQL、邮件服务与企业应用实践

MySQL、邮件服务与企业应用实践 数据库选择依据 在设计不同类型的应用时,数据库的选择至关重要。对于人力资源应用,由于数据具有关系性,如员工的姓名、社保号码、工资等相关信息,选择关系型数据库是合适的。而对于多媒体应用,像照片、视频和艺术作品等,对象数据库更为流…

作者头像 李华
网站建设 2026/6/17 9:10:24

21、BIND与DHCP在DNS中的应用详解

BIND与DHCP在DNS中的应用详解 1. 反向查找区域文件 在示例反向查找区域文件中,存在一个针对网络 10.1.1.0/24 的反向区域。 $ORIGIN 指令是可选的,但它能让区域文件更易读,该指令主要用于补全未完全限定的资源记录(RRs)。例如,当使用IP地址 10.1.1.[1,2,6] 时, …

作者头像 李华
网站建设 2026/6/18 1:55:57

27、Linux 系统故障排查与性能优化指南

Linux 系统故障排查与性能优化指南 1. 进程排查工具——ps 命令 在排查进程相关问题时, ps 命令非常实用。以下是几个常见的 ps 命令选项及示例: - 查看进程运行时间 :可以帮助解决内存耗尽问题。例如,查看 init 和 rsyslog 进程的运行时间: $ ps -eo pid,c…

作者头像 李华