对于图像的加密和解密,常见算法:
1 加密,将原始图像和密钥图像 进行按位异或得到加密后的图像
2 解密 将加密后的图像和密钥图像 进行按位异或,得到原始图像
原理如下
数字A = 1011 0011
数字B = 0100 1110
加密后 C = A xor B = 1111 1101
解密后 D = C xor B = 1011 0011
通过仔细观察,不难发现:D的值和A的值相等
原理部分参考:利用Python+OpenCV对图像加密/解密_图像加密用什么编译器-CSDN博客
代码如下:
import cv2
import numpy as np
import cv2
import numpy as np
#读取图像
lena=cv2.imread("lena.bmp",0)
#获取图像的尺寸
r,c=lena.shape
# 生成密钥图像
key=np.random.randint(0,256,size=[r,c],dtype=np.uint8)
# 将原始图像和密钥图像 进行按位异或得到加密后的图像
encryption=cv2.bitwise_xor(lena,key)
# 将加密后的图像和密钥图像 进行按位异或,得到原始图像
decryption=cv2.bitwise_xor(encryption,key)
# 展示原始图像
cv2.imshow("lena",lena)
# 展示密钥图像
cv2.imshow("key",key)
# 展示加密后的图像
cv2.imshow("encryption",encryption)
# 展示解密后的图像
cv2.imshow("decryption",decryption)
cv2.waitKey()
cv2.destroyAllWindows()
结果
原始图像:
key
加密后的图像
解密后的图像