相比于以前的实现方式,处理了文件超过堆内存限制的文件做数字信封。现在的支持任何大小的数字信封。速度的话基本上1G的文件加密在50s秒左右!

上期的数字信封SM4工具类如果文件太大会报 OutOfMemoryError: Java heap space  内存溢出

以前的实现方法: 一次性将文件中的字节都读出来,直接一次性加密。但是忽略了一点,jvm的内存有限,内存不可能一直无限的增加下去,所以当文件大到一定程度就会报内存溢出。

解决方法:

  1. 我们可以调节jvm的内存,调节到我们需要的大小。 缺点:不太友好,如果又来一个大一点的又要重新调,并且不能无限增加下去。局限性
  2. 可以将文件分成几份加密。解密也是分开解密,解完后在合并。  缺点: 理论上可行。但是太繁琐,而且要实现加密后写入文件时的标记功能。
  3. 将现有的字节加密换成流加密, 即:CipherOutputStreamCipherInputStream。 缺点: 直接写出output,不太灵活。

我们采用第三种方式优化代码,虽然不太灵活,但是他没有局限性,无论多大的文件理论上都是可以加密的,原理其实和第二种方式差不多,我们会手动建立一个字节缓冲区,一边读文件一边写文件。对加密的速度也会有所提升。

上代码:

sm4流加密
 //in 待加密文件的输入流  encryptPath: 加密后的保存路径 public static boolean encrypt_ECB_Padding(byte[] key, InputStream in,String encryptPath)          throws InvalidKeyException, NoSuchAlgorithmException, NoSuchProviderException,            NoSuchPaddingException, IllegalBlockSizeException, BadPaddingException, IOException {     Cipher cipher = generateECBCipher(ALGORITHM_NAME_ECB_PADDING, Cipher.ENCRYPT_MODE, key);     //定义输出流       OutputStream out = new FileOutputStream(encryptPath);        CipherOutputStream cipherOut = new CipherOutputStream(out,cipher);       IOUtils.copy(in, cipherOut);      cipherOut.close();        in.close();       out.close();      return true;    } //in 待解密文件的输入流 decryptPath: 解密后的保存路径 public static boolean decrypt_ECB_Padding(byte[] key,InputStream in,String decryptPath)          throws IllegalBlockSizeException, BadPaddingException, InvalidKeyException,           NoSuchAlgorithmException, NoSuchProviderException, NoSuchPaddingException , IOException{      Cipher cipher = generateECBCipher(ALGORITHM_NAME_ECB_PADDING, Cipher.DECRYPT_MODE, key);     //定义输出流       OutputStream out = new FileOutputStream(decryptPath);        CipherOutputStream cipherOut = new CipherOutputStream(out,cipher);       IOUtils.copy(in, cipherOut);      cipherOut.close();        in.close();       out.close();      return  true;    }

这里的代码只是核心部分代码的修改,有兄弟想看全部项目的代码可以添加右下角的微信!

也可以通过我的gitee来获取。 拜拜!

SM2SM4实现字符串和文件的数字信封(不限制文件大小)相关推荐

  1. SM2SM4实现字符串和文件的数字信封(小文件不支持超过堆内存的大文件)

    先解释一下什么是数字信封:  将对称密钥通过非对称加密(即:有公钥和私钥两个)的结果分发对称密钥的方法.大白话讲: 用对称秘钥对文件或字节加密,然后用非对称秘钥对对称秘钥的钥匙进行加密. 这里再解释一 ...

  2. chewing的作业——数字信封实现文件传输

    文件安全传输系统设计作业 通信模式:端到端通信 数字信封:   对称密码优点是加解密运算非常快,适合处理大批量数据,但其密码的分发与管理比较复杂.而非对称密码算法的特点是公钥和私钥分离,非常适合密钥的 ...

  3. java p7 数字签名,p7结构的数字信封 | 学步园

    PKCS7的数字信封格式分为两种:带签名的数字信封和不带签名的数字信封.由于这个数字信封的生成过程比较复杂,所以这两种格式比较容易记混,导致都搞不清楚一个数字信封里面到底是存储的什么内容了.下面我就详 ...

  4. C#.NET 国密数字信封 民生银行

    民生银行的库DLL只有C版本和JAVA版本.按着JAVA版本做的C# 实现. 重点内容. 1.数字信封就是 CmsEnvelopedData Der编码后转BASE64 2.重点类:ContentIn ...

  5. 密码学之数字信封 Digital_Envelope

    东华大学信息安全专业,大三(下),系统安全课程设计实验 实验五  安全数据传输实验 一.实验目的 掌握对称密码和公钥密码体制的原理,通过综合使用两种加解密方式,了解两种加解密方式的异同点及认证方式. ...

  6. sm2格式数字信封加解密详解

    sm2格式数字信封 0.参考链接 密码行业标准化技术委员会http://www.gmbz.org.cn/main/bzlb.html SM2密码算法使用规范http://www.gmbz.org.cn ...

  7. vc++网络安全编程范例(19)实现数字信封打包与拆解

    数字信封是将对称密钥通过非对称加密(即:有公钥和私钥两个)的结果分发对称密钥的方法. PKCS#7中将数字信封作为术语进行定义,而在正文中对进行了如下解释:数字信封包含被加密的内容和被加密的用于加密该 ...

  8. 文件魔术数字_如何使用魔术脚手架自动创建文件并节省时间

    文件魔术数字 Before we begin: This article uses JavaScript / Node.js example code, but you can port these ...

  9. Swift3.0语言教程字符串与文件的数据转换

    Swift3.0语言教程字符串与文件的数据转换 Swift3.0语言教程字符串与文件的数据转换,如果想要对字符串中的字符进行永久保存,可以将字符串中的字符写入到文件中.当然,开发者也可以将写入的内容进 ...

最新文章

  1. Python数据集可视化:抽取数据集的两个特征进行二维可视化、主成分分析PCA对数据集降维进行三维可视化(更好地理解维度之间的相互作用)
  2. jsp中有关于超链接的问题
  3. java内存中的栈、方法区 、堆
  4. element ui 获取文件的路径_win10使用WinAppDriver实现UI自动化
  5. 洛谷 P1202 模拟 - 黑色星期五 Friday the Thirteenth
  6. P3690-[模板]Link Cut Tree(动态树)【Splay】
  7. java切面1.6需要的包_Java技术 AspectJ
  8. Android属性动画赏析,Android源码分析—属性动画的工作原理
  9. keepalived高可用配置注意事项
  10. java环境变量设置图解_Java环境变量一键配置操作方法
  11. 参考手册资源 百度云
  12. 电容或电感的电压_纯电阻、纯电感和纯电容电路
  13. LabVIEW心率监测装置
  14. UE4基础知识总结(一)
  15. 短信验证码接收app必须注意的那些事
  16. AJAX框架眼镜穿搭夏天,30度的夏天,男生应该如何穿搭?看这9种时尚组合!
  17. K12在线教育行业和产品分析报告
  18. PLC通讯实现-C#实现西门子PLC以太网通讯Sharp7(六)
  19. Spring Cloud 异常“ Caused by: java.net.UnknownHostException: discovery.host ”
  20. Jmeter接口测试+压力测试

热门文章

  1. 矩阵分解 SVD 和 CUR的区别
  2. 论文阅读 (58):Research and Implementation of Global Path Planning for Unmanned Surface Vehicle Based...
  3. 说说微信红包算法,为什么你总是抢的那么少?
  4. Retrofit学习
  5. 20181212股票复盘
  6. 闲鱼是如何实践一套完整的埋点自动化验证方案的?
  7. 全面认识Scratch少儿编程
  8. “工赋”三问:从青岛到德阳,卡奥斯如何实现跨区域复制?
  9. PERT(计划评审技术Program Evaluation an Review Technique)
  10. 【google翻译】使用Ola Hallengren的脚本更新统计数据