使用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). (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容