博客
关于我
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中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>