博客
关于我
CTFlearn-Image Magic
阅读量:314 次
发布时间:2019-03-03

本文共 897 字,大约阅读时间需要 2 分钟。

It looks like someone messed up my picture! Can anyone reorganize the pixels? The python module PIL (Python Imaging Library) might be useful! https://mega.nz/#!OKxByZyT!vaabCJRG5D9zAUp7drTekcA5pszu67r_TbQMtxEzqGE

Update: I think whoever messed up my image took every column of pixels and put them side by side. Update: I think the width of the image was 304 before they messed with it.

一道PIL编程问题, 顺便把PIL各个接口学了, 关于编辑image, 需要的接口有new(“RGB”, (x, y)), Image.size是行和列, 看大小发现是一行27986个像素点的一维图片, 题目说每行304个, 所以一共92行, 转换成原图, 脚本如下

from PIL import ImageIm =  Image.open("out copy.jpg")Img_flag = Image.new("RGB", (500, 500))fx, fy = 0, 0rows = Im.size[0]for i in range(rows):    r, g, b = Im.getpixel((i, 0))    fx = (i % 92) # 27968 // 304 == 92    if i % 92 == 0: fy += 1 # 增加一行    Img_flag.putpixel((fy, fx), (r, g, b)) # fx, fy发现图片旋转了90度, 对换一下x, yImg_flag.show()Img_flag.save("flag.jpg")

在这里插入图片描述

flag{cool_right?}

转载地址:http://pnfq.baihongyu.com/

你可能感兴趣的文章
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>