加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

使用JAVA使用AES加密大文件

发布时间:2020-12-14 23:40:02 所属栏目:Java 来源:网络整理
导读:我用低于此值的文件(10mb,100mb,500mb)测试了我的代码,加密工作正常.但是,我遇到了大于1GB的文件的问题. 我已经生成了一个大文件(大约2GB),我想用AES使用JAVA加密它,但我遇到了这个错误: “线程中的异常”主“java.lang.OutOfMemoryError:Java堆空间” 我
我用低于此值的文件(10mb,100mb,500mb)测试了我的代码,加密工作正常.但是,我遇到了大于1GB的文件的问题.
我已经生成了一个大文件(大约2GB),我想用AES使用JAVA加密它,但我遇到了这个错误:

“线程中的异常”主“java.lang.OutOfMemoryError:Java堆空间”

我尝试使用-Xmx8G增加可用内存,但没有骰子.
我的部分代码如下

File selectedFile = new File("Z:dummy.txt");         
    Path path = Paths.get(selectedFile.getAbsolutePath());       
    byte[] toencrypt = Files.readAllBytes(path);       
    byte[] ciphertext = aesCipherForEncryption.doFinal(toencrypt);
    FileOutputStream fos = new FileOutputStream(selectedFile.getAbsolutePath());
    fos.write(ciphertext);
    fos.close();

据我所知,它的行为方式是,它试图立即读取整个文件,加密它,并将其存储到另一个字节数组中,而不是缓冲和流式传输.任何人都可以帮助我一些代码提示?

我是编码的初学者,所以我真的不太了解,任何帮助都将受到赞赏.

解决方法

甚至不要尝试将整个大文件读入内存.一次加密缓冲区.只需使用包含在FileOutputStream周围的适当初始化的CipherOutputStream执行标准复制循环.你可以将它用于所有文件,不需要特殊情况.使用8k或更高的缓冲区.

编辑Java中的“标准拷贝循环”如下:

byte[] buffer = new byte[8192];
int count;
while ((count = in.read(buffer)) > 0)
{
    out.write(buffer,count);
}

在这种情况下out = new CipherOutputStream(new FileOutputStream(selectedFile),cipher).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读