aes sample java,python-AES加密java解密

这篇博客探讨了如何使用AES加密在Python中加密文件,并在Java(Android应用)中进行解密。作者分享了一段Python代码,该代码使用CBC模式和随机生成的初始化向量进行加密。遇到的主要问题是密钥的传输和解密过程中的填充问题。在Java端,提供的代码似乎未能正确处理解密过程。博客寻求帮助以解决Java解密部分的问题,特别是填充和密钥同步的问题。
摘要由CSDN通过智能技术生成

我有超过1000个图像和视频需要加密。没什么比这更简单的了,我想用AES,但我搞不懂如何在我的电脑上加密,然后在设备上解密。在

我会用python加密我电脑上的所有项目。然后以随需应变的方式用java(Android应用程序)解密物品

任何简单的解释都可以实现伪代码。在

我面临的主要问题是如何使用同一个密钥来加密和解密。我一直在生成密钥,但无法将其传输到另一个设备进行解密。在

谢谢

Python代码。工作加密和解密。在from Crypto.Cipher import AES

import os, random, struct

key = '0123456789abcdef'

mode = AES.MODE_CBC

chunksize = 64*1024

iv = ''.join(chr(random.randint(0,0xFF)) for i in range(16))

encryptor = AES.new(key,mode,iv)

filesize = os.path.getsize('sample.jpg')

with open('sample.jpg','rb') as infile:

with open('sample.enc','wb') as outfile:

outfile.write(struct.pack('

outfile.write(iv)

while True:

chunk = infile.read(chunksize)

if len(chunk) == 0:

break

elif len(chunk) % 16 != 0:

chunk += ' ' * (16 - len(chunk) % 16)

outfile.write(encryptor.encrypt(chunk))

## decrypt

with open('sample.enc', 'rb') as infile:

origsize = struct.unpack('

iv = infile.read(16)

decryptor = AES.new(key, AES.MODE_CBC, iv)

with open('sample2.jpg', 'wb') as outfile:

while True:

chunk = infile.read(chunksize)

if len(chunk) == 0:

break

outfile.write(decryptor.decrypt(chunk))

outfile.truncate(origsize)

如何在Java中完成解密部分?这是我快速的草率的java代码,它不起作用。我想是填充物把事情搞砸了。在

^{pr2}$

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值