博客
关于我
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 DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>
MuseTalk如何生成高质量视频(使用技巧)
查看>>
mutiplemap 总结
查看>>
MySQL DELETE 表别名问题
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>
MVC 区域功能
查看>>
MySQL FEDERATED 提示
查看>>
mysql generic安装_MySQL 5.6 Generic Binary安装与配置_MySQL
查看>>
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>