public static void sample(BufferedImage image) {
    int width = image.getWidth();
    int height = image.getHeight();
    int value[][] = new int[width][height];
    int valueR[][] = new int[width][height];
    int valueG[][] = new int[width][height];
    int valueB[][] = new int[width][height];
    for (int j = 0; j < height; j++) {
        for (int i = 0; i < width; i++) {
            int pixel = image.getRGB(i, j);
            value[i][j] = pixel;
            Color c = new Color(pixel);
            valueR[i][j]= c.getRed();
            valueG[i][j] = c.getGreen();
            valueB[i][j] = c.getBlue();  
            System.out.println("Red value = "+valueR[i][j]);
            System.out.println("Green value ="+valueG[i][j]);
            System.out.println("Blue value"+valueB[i][j]);
        }
    }
}
上面的代码是将图像的RGB值和像素颜色值分别存储在一个数组中。
 public static BigInteger modPow(BigInteger a1, BigInteger e, BigInteger n) {
    BigInteger r = 1;
    for (int i = e.bitLength() - 1; i >= 0; i--) {
        r = (r.multiply(r)).mod(n);
        if (e.testBit(i)) {
            r = (r.multiply(a1)).mod(n);
        }
    }
    System.out.println("C value = " + r);
    int lng = 3;
    BigInteger bi = BigInteger.valueOf(lng);
    BigInteger a = r.divide(bi);
    BigInteger b = r.mod(bi);
    System.out.println("pixel position a = " + a);
    System.out.println("modulus value b = " + b);
    return r;
}
在上面的代码中,我找到了我需要嵌入秘密位的像素位置。所以我需要去那个特定的像素来嵌入消息。但是在前面的代码中,我将像素颜色存储在数组值 [] [] 中。我需要搜索数组 value[][] 以获取我在最后一个代码中得到的像素位置。
注意: a1 是当前要嵌入的信息文件位的位置 {e,n} 是公钥
我的问题是如何找到像素位置?