XOR

可用stegsolve异或,不再赘述

BlindWaterMark

就是俗称的盲水印,一般比较简单,直接使用网上的脚本即可,这次发现了不一样的脚本,故此记录一下。

1.最常用的脚本

https://github.com/chishaxie/BlindWaterMark

2.这次遇到的题是**[GWCTF2019]huyao**

直接使用如上脚本不能得到有用信息

使用

https://xz.aliyun.com/t/1875/

内介绍的频域盲水印隐写脚本可得flag

# coding=utf-8

import cv2

import numpy as np

import random

import os

from argparse import ArgumentParser

ALPHA = 5

 

 

def build_parser():

    parser = ArgumentParser()

    parser.add_argument('--original', dest='ori', required=True)

    parser.add_argument('--image', dest='img', required=True)

    parser.add_argument('--result', dest='res', required=True)

    parser.add_argument('--alpha', dest='alpha', default=ALPHA)

    return parser

 

 

def main():

    parser = build_parser()

    options = parser.parse_args()

    ori = options.ori

    img = options.img

    res = options.res

    alpha = options.alpha

    if not os.path.isfile(ori):

        parser.error("original image %s does not exist." % ori)

    if not os.path.isfile(img):

        parser.error("image %s does not exist." % img)

    decode(ori, img, res, alpha)

 

 

def decode(ori_path, img_path, res_path, alpha):

    ori = cv2.imread(ori_path)

    img = cv2.imread(img_path)

    ori_f = np.fft.fft2(ori)

    img_f = np.fft.fft2(img)

    height, width = ori.shape[0], ori.shape[1]

    watermark = (ori_f - img_f) / alpha

    watermark = np.real(watermark)

    res = np.zeros(watermark.shape)

    random.seed(height + width)

    x = range(height / 2)

    y = range(width)

    random.shuffle(x)

    random.shuffle(y)

    for i in range(height / 2):

        for j in range(width):

            res[x[i]][y[j]] = watermark[i][j]

    cv2.imwrite(res_path, res, [int(cv2.IMWRITE_JPEG_QUALITY), 100])

 

 

if __name__ == '__main__':

    main()

 `

脚本命令如下

python decode.py --original huyao.png --image stillhuyao.png --result res.png

3.还有直接使用软件生成的盲水印

软件:WaterMarkH

容差比较

使用工具:beyond compare

题目资源(忘了哪个比赛了)

to

to_do

3