【CTF】用python PIL将RGB值转化为图片
1. 题目介绍
题目的名称叫:神奇的二维码
flag格式为:flag{}
给出了一个flag.txt文件
链接:http://pan.baidu.com/s/1kUBHZBD 密码:zzxo
2. 思路分析
打开后发现是(255, 255, 255)和(0, 0, 0),这不是R.G.B嘛,(255, 255, 255)代表白色,(0, 0, 0)代表黑色。结合题目是二维码,想考差的就很明显了,那就是将这些RGB转换成像素输出成图片。
python里有个PIL库就是处理图片信息的,python3中已经换成了Pillow
flag.txt一共有78400行(最后一行是空行不计算在内),78400分解成2×2×2×2×2×2×5×5×7×7,组合了半天想起来二维码一般都是正方形的,正好78400是280的平方。
这里放出将RGB转换为像素的代码,本人菜狗子一个,如果有错误或者不足之处还望大佬们指出。
from PIL import Image
x = 280 #x坐标 通过对txt里的行数进行整数分解
y = 280 #y坐标 x * y = 行数
im = Image.new("RGB", (x, y)) #创建图片
file = open('flag.txt') #打开rbg值的文件
#通过每个rgb点生成图片
for i in range(0, x):
for j in range(0, y):
line = file.readline() #获取一行的rgb值
rgb = line.split(", ") #分离rgb,文本中逗号后面有空格
im.putpixel((i, j), (int(rgb[0]), int(rgb[1]), int(rgb[2]))) #将rgb转化为像素
im.show() #也可用im.save('flag.jpg')保存下来
这里需要注意的是文本中rbg值是用()括起来的,所以还要想办法把()解决掉才能运行。
运行后得到图片
扫码后得到一串字符:ONYXE6LSIVXF6ZTUOZTXWRRRIRPWCZLWORIGCLJQG56Q====
base32解码后得到
发现位置是混乱的,想到了凯撒加密,但是凯撒解密出来都不对,想起来格式是flag,那么位置也被移位了,所以先用栅栏密码解码
发现第1栏前面是4位,这时我们再拿去做凯撒解密
3. 相关文档
Pillow库介绍:
原文档:http://pillow.readthedocs.io/en/latest/
翻译文档:http://www.cnblogs.com/apexchu/p/4231041.html
关于base64 32 16介绍:
http://xiaoqin00.blog.51cto.com/10468367/1718416
栅栏密码介绍:
百度百科:https://baike.baidu.com/item/%E6%A0%85%E6%A0%8F%E5%AF%86%E7%A0%81/228209?fr=aladdin
上一篇: thinkphp3.2最新版的分页文件可带ajax功能
下一篇: [zz]PHP 正则