图像的hash置乱基本思想:对于图像中mxn个像素点,要求对每个像素进行随机置换,可采用安全hash函数生成随机的行号表和列号表,根据图像中的像素个数,从行号表和列号表中依次取值,读取的行号x和列号y对应为原图像中像素a(x, y)的坐标,将a(x, y)放置在结果图像result(i,j)处,以上过程通过mxn次循环操作,最后得到置乱图像。
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
/**
* @author ArtemisKhryso
* @time 2021/4/18
*/
public class HashDisorder {
public static void main(String[] args) throws IOException {
//图像操纵对象
BufferedImage img = ImageIO.read(new File("img/source.jpg"));
//图片类型
int imgType = img.getType();
int imgHight = img.getHeight();
int imgWidth = img.getWidth();
//行号列号集合表 1~i,1~j
ArrayList<Integer> hightForm = new ArrayList<Integer>();
for (int i = 0; i<imgHight; i++){
hightForm.add(i);
}
ArrayList<Integer> widthForm = new ArrayList<Integer>();
for (int j = 0; j<imgWidth; j++){
widthForm.add(j);
}
//无法恢复的打乱算法,使用默认随机源进行置乱
Collections.shuffle(hightForm);
Collections.shuffle(widthForm);
//原像素数组
int[][] source = new int[imgWidth][imgHight];
//置乱后像素数组
int[][] result = new int[imgWidth][imgHight];
//记录原像素信息到source矩阵里
for (int i = 0; i < imgWidth; i++) {
for (int j = 0; j < imgHight; j++) {
source[i][j] = img.getRGB(i, j) & 0xFFFFFF;
}
}
//按置乱集合表的行列进行取值,构造新矩阵
for (int i = 0; i < imgWidth; i++) {
for (int j = 0; j < imgHight; j++) {
result[i][j] = source[widthForm.get(i)][hightForm.get(j)];
}
}
//按新矩阵从原图片取像素,添加像素点到图片对象相应位置生成新图片
BufferedImage img2 = new BufferedImage(imgWidth, imgHight, imgType);
for (int i = 0; i < imgWidth; i++) {
for (int j = 0; j < imgHight; j++) {
img2.setRGB(i,j,result[i][j] & 0xFFFFFF);
}
}
//输出文件
File file = new File("img/result.jpg");
try {
ImageIO.write(img2, "jpg", file);
} catch (IOException e) {
e.printStackTrace();
}
}
}
source.jpg
result.jpg
没准备恢复,先就置乱吧,要想恢复,把行列表的置乱算法改一下就行了。