攻防世界-Misc-2-1

知识点

1.png文件头

2.png文件宽高

步骤

1.题目描述

附件为一张图片,打开报错。用010打开发现png文件头不对。

复制代码
png的文件头:
- (固定)八个字节89 50 4E 47 0D 0A 1A 0A为png的文件头
- (固定)四个字节00 00 00 0D(即为十进制的13)代表数据块的长度为13
- (固定)四个字节49 48 44 52(即为ASCII码的IHDR)是文件头数据块的标示(IDCH)
- (可变)13位数据块(IHDR)
  - 前四个字节代表该图片的宽
  - 后四个字节代表该图片的高
  - 后五个字节依次为:
    Bit depth、ColorType、Compression method、Filter method、Interlace method
- (可变)剩余四字节为该png的CRC检验码,由从IDCH到IHDR的十七位字节进行crc计算得到

2.修改文件头

修改完后任然无法打开,猜测crc校验值不对,修改成正确的宽高。

3.修改宽高

python脚本获取正确宽高
复制代码
# 求图片宽高

import binascii
import struct

crcbp = open("5.png", "rb").read()  # 打开图片
crc32frombp = int(crcbp[29:33].hex(), 16)  # 读取图片中的CRC校验值
print(crc32frombp)

for i in range(4000):  # 宽度1-4000进行枚举
    for j in range(4000):  # 高度1-4000进行枚举
        data = crcbp[12:16] + \
               struct.pack('>i', i) + struct.pack('>i', j) + crcbp[24:29]
        crc32 = binascii.crc32(data) & 0xffffffff
        # print(crc32)
        if (crc32 == crc32frombp):  # 计算当图片大小为i:j时的CRC校验值,与图片中的CRC比较,当相同,则图片大小已经确定
            print(i, j)
            print('hex:', hex(i), hex(j))
            exit(0)

修改宽高为:02C5 02F8

打开图片即得到flag。

flag:wdflag{Png_C2c_u_kn0W}

相关推荐
宋浮檀s8 小时前
应急响应——恶意流量&攻击行为识别
linux·运维·网络·网络安全·应急响应
谪星·阿凯11 小时前
内网渗透之权限维持:从域环境到单机的持久化控制指南
运维·服务器·网络·网络安全
宋浮檀s11 小时前
春秋云镜——CVE-2022-22965
网络·安全·web安全·网络安全
大方子14 小时前
【好靶场】交易所钱包划转存在的逻辑漏洞3
网络安全·好靶场
行走的陀螺仪19 小时前
[特殊字符]️ 前端 + Node.js + Nginx 安全防护终极指南:从入门到实战(2025最新版)
web安全·网络安全
сокол19 小时前
【网安-Web渗透测试-免杀系列】加壳加密
网络安全
Inhand陈工1 天前
游轮WiFi覆盖方案复盘:6台5G CPE + AP实现全船高速上网
人工智能·物联网·网络协议·网络安全·信息与通信·iot
君如风军如风1 天前
等保2.0安全通用要求第三级别之安全通信网络
网络安全·等级保护·等保2.0·安全合规·gb/t 22239
锐速网络2 天前
静态资源加速+WAF防护,构建企业安全加速一体化架构
网络安全·网站安全·cdn加速·应用层防护·静态资源加速·waf防护·企业web防护
vortex52 天前
THC-IPv6 攻击工具包:IPv6 渗透测试
网络安全·ipv6