博客
关于我
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事务及其特性与锁机制
查看>>
mysql事务理解
查看>>
MySQL事务详解结合MVCC机制的理解
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
webpack css文件处理
查看>>
mysql二进制包安装和遇到的问题
查看>>
MySql二进制日志的应用及恢復
查看>>
mysql互换表中两列数据方法
查看>>
mysql五补充部分:SQL逻辑查询语句执行顺序
查看>>
mysql交互式连接&非交互式连接
查看>>
MySQL什么情况下会导致索引失效
查看>>
Mysql什么时候建索引
查看>>
MySql从入门到精通
查看>>
MYSQL从入门到精通(一)
查看>>
MYSQL从入门到精通(二)
查看>>
mysql以下日期函数正确的_mysql 日期函数
查看>>
mysql以服务方式运行
查看>>
mysql优化--索引原理
查看>>
MySQL优化之BTree索引使用规则
查看>>