我正在尝试使用python Crypto解密一些加密的.jpg图像
def decrypt(input_filename, output_filename, password, cipher):
ciphers = ['AES_ECB']
key = generate_key(password)
#Loading Pixel Data
im = Image.open(input_filename)
pix = im.load()
rgb_im = im.convert('RGB')
size = im.size
image = Image.new('RGB', im.size)
pix1=image.load()
print "Filesize: " + str(size)
for x in range(256):
for y in range (256):
pixel = rgb_im.getpixel((x, y))
print pixel#DEBUG
if cipher == ciphers[0]:
print x,y
pix1[x,y] = decryptPixel(pixel, key)
image.save(output_filename)
但我有这个错误:
17 if cipher == ciphers[0]:
18 print x,y
---> 19 pix1[x,y] = decryptPixel(pixel, key)
20 image.save(output_filename)
OverflowError: Python int too large to convert to C long
你能帮我解决一下这个问题吗?
def decryptPixelComponent(component, key):
decryptor = AES.new(key, AES.MODE_ECB)
component_hash = hashlib.sha256(str(component)).digest()
component = decryptor.decrypt(component_hash).encode('hex')
#print int(component, 16)
return int(component, 16)
def decryptPixel(pixel, key):
(red, green, blue) = pixel
return (decryptPixelComponent(red, key),
decryptPixelComponent(green, key),
decryptPixelComponent(blue, key))
来自" decryptPixel"的结果是元组,pix1也是元组。但是,当我尝试更新pix1时,我遇到了这个溢出错误。
答案 0 :(得分:0)
查看“decryptPixelComponent”函数,您似乎正在解密像素的哈希值(“component_hash”)。我认为你应该尝试解密没有哈希(“组件”)。
def decryptPixelComponent(component, key):
decryptor = AES.new(key, AES.MODE_ECB)
component = decryptor.decrypt(component).encode('hex')
#print int(component, 16)
return int(component, 16)