攻防世界-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}

相关推荐
LuminescenceJ12 小时前
GoEdge 开源CDN 架构设计与工作原理分析
分布式·后端·网络协议·网络安全·rpc·开源·信息与通信
大方子15 小时前
【PolarCTF】$$
网络安全·polarctf
大方子16 小时前
【PolarCTF】LSB
网络安全·polarctf
浩浩测试一下16 小时前
应急响应之 洪水 Floods attack ==== DDOS
安全·web安全·网络安全·系统安全·ddos·安全架构
大方子17 小时前
【PolarCTF】超级简单的流量
网络安全·polarctf
大方子17 小时前
【PolarCTF】爆破鬼才
网络安全·polarctf
heze0918 小时前
sqli-labs-Less-26
数据库·mysql·网络安全
Lust Dusk18 小时前
如何通过GitHub找到一个人?
安全·网络安全·github
安全渗透Hacker18 小时前
Nmap自定义NSE脚本实战:从入门到落地
网络安全·安全性测试
heze0919 小时前
sqli-labs-Less-26a
数据库·mysql·网络安全