emmm,研究了一会,也看了官方的wp用的是脚本,只能说,小生惭愧,看布懂
通过观察可以发现,图片名字无序

按日期升序,打开第三张图片,可以发现两块二维码的定位符,证明出题人没把修改日期random掉,也就是说,按日期排序,照片是有序的
接着我们Ctrl+A全选图片,右键第一张图片,点击重命名

修改为flag,接着回车

这样子图片名字也有序了,接着我们利用在线工具在线多图合一拼图工具 - UU在线工具

如图设置完每张图片的宽高间距等,将图片全部拖入,然后点击合并

下载图片,然后用PS打开

将亮度拉满,对比度掉最低,然后保存扫码,得到flag

flag{You Can Repair A Picture From Splices Baesd On Entropy}
抄wp里的脚本,只是将python2格式改成了python3,加了一些注释,可惜我没完全看懂
- import cv2
- import os
- import numpy
- import copy
- import itertools
- import math
-
- images = []
-
- def judge(A, B):
- diff = 0
- for r in range(0, len(A)):
- #diff += (A[r][len(A[0]) - 1][0] - B[r][0])[0]
- #diff += (A[r][len(A[0]) - 1][1] - B[r][0])[1]
- diff += (A[r][len(A[0]) - 1][2] - B[r][0])[2] ** 0.25
- return diff
-
- def combine(A, B):
- final_matrix = numpy.zeros((len(A), len(A[0]) + len(B[0]), 3), numpy.uint8)
- final_matrix[0:len(A), 0:len(A[0])] = A
- final_matrix[0:len(A), len(A[0]):len(A[0]) + len(B[0])] = B
- return final_matrix
-
- if __name__ == "__main__":
- f_images = os.listdir("./images") #获取images目录下所有文件或文件夹(不包括.和..)
- for f_image in f_images:
- images.append(
- cv2.imread(
- "images\\" + f_image
- )
- ) #列表存放OpenCV读取的图片
- while len(images) > 1:
- min_entropy = -1
- to_combine = None
- for i in range(1, len(images)):
- entropy = judge(images[0], images[i])
- if min_entropy == -1 or entropy < min_entropy:
- min_entropy = entropy
- to_combine = i
- images[0] = combine(images[0], images[to_combine])
- print(len(images), len(images[0][0]))
- images.pop(to_combine)
- cv2.imwrite("./result.png", images[0])
-
根据人工智能算法拼接的二维码图片,得到的结果是分半的二维码,PS修复一下即可