SM2SM4实现字符串和文件的数字信封(不限制文件大小)
相比于以前的实现方式,处理了文件超过堆内存限制的文件做数字信封。现在的支持任何大小的数字信封。速度的话基本上1G的文件加密在50s秒左右!
上期的数字信封SM4工具类如果文件太大会报 OutOfMemoryError: Java heap space 内存溢出
以前的实现方法: 一次性将文件中的字节都读出来,直接一次性加密。但是忽略了一点,jvm的内存有限,内存不可能一直无限的增加下去,所以当文件大到一定程度就会报内存溢出。
解决方法:
- 我们可以调节jvm的内存,调节到我们需要的大小。 缺点:不太友好,如果又来一个大一点的又要重新调,并且不能无限增加下去。局限性
- 可以将文件分成几份加密。解密也是分开解密,解完后在合并。 缺点: 理论上可行。但是太繁琐,而且要实现加密后写入文件时的标记功能。
- 将现有的字节加密换成流加密, 即:CipherOutputStream与CipherInputStream。 缺点: 直接写出output,不太灵活。
我们采用第三种方式优化代码,虽然不太灵活,但是他没有局限性,无论多大的文件理论上都是可以加密的,原理其实和第二种方式差不多,我们会手动建立一个字节缓冲区,一边读文件一边写文件。对加密的速度也会有所提升。
上代码:
//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实现字符串和文件的数字信封(不限制文件大小)相关推荐
- SM2SM4实现字符串和文件的数字信封(小文件不支持超过堆内存的大文件)
先解释一下什么是数字信封: 将对称密钥通过非对称加密(即:有公钥和私钥两个)的结果分发对称密钥的方法.大白话讲: 用对称秘钥对文件或字节加密,然后用非对称秘钥对对称秘钥的钥匙进行加密. 这里再解释一 ...
- chewing的作业——数字信封实现文件传输
文件安全传输系统设计作业 通信模式:端到端通信 数字信封: 对称密码优点是加解密运算非常快,适合处理大批量数据,但其密码的分发与管理比较复杂.而非对称密码算法的特点是公钥和私钥分离,非常适合密钥的 ...
- java p7 数字签名,p7结构的数字信封 | 学步园
PKCS7的数字信封格式分为两种:带签名的数字信封和不带签名的数字信封.由于这个数字信封的生成过程比较复杂,所以这两种格式比较容易记混,导致都搞不清楚一个数字信封里面到底是存储的什么内容了.下面我就详 ...
- C#.NET 国密数字信封 民生银行
民生银行的库DLL只有C版本和JAVA版本.按着JAVA版本做的C# 实现. 重点内容. 1.数字信封就是 CmsEnvelopedData Der编码后转BASE64 2.重点类:ContentIn ...
- 密码学之数字信封 Digital_Envelope
东华大学信息安全专业,大三(下),系统安全课程设计实验 实验五 安全数据传输实验 一.实验目的 掌握对称密码和公钥密码体制的原理,通过综合使用两种加解密方式,了解两种加解密方式的异同点及认证方式. ...
- sm2格式数字信封加解密详解
sm2格式数字信封 0.参考链接 密码行业标准化技术委员会http://www.gmbz.org.cn/main/bzlb.html SM2密码算法使用规范http://www.gmbz.org.cn ...
- vc++网络安全编程范例(19)实现数字信封打包与拆解
数字信封是将对称密钥通过非对称加密(即:有公钥和私钥两个)的结果分发对称密钥的方法. PKCS#7中将数字信封作为术语进行定义,而在正文中对进行了如下解释:数字信封包含被加密的内容和被加密的用于加密该 ...
- 文件魔术数字_如何使用魔术脚手架自动创建文件并节省时间
文件魔术数字 Before we begin: This article uses JavaScript / Node.js example code, but you can port these ...
- Swift3.0语言教程字符串与文件的数据转换
Swift3.0语言教程字符串与文件的数据转换 Swift3.0语言教程字符串与文件的数据转换,如果想要对字符串中的字符进行永久保存,可以将字符串中的字符写入到文件中.当然,开发者也可以将写入的内容进 ...
最新文章
- Python数据集可视化:抽取数据集的两个特征进行二维可视化、主成分分析PCA对数据集降维进行三维可视化(更好地理解维度之间的相互作用)
- jsp中有关于超链接的问题
- java内存中的栈、方法区 、堆
- element ui 获取文件的路径_win10使用WinAppDriver实现UI自动化
- 洛谷 P1202 模拟 - 黑色星期五 Friday the Thirteenth
- P3690-[模板]Link Cut Tree(动态树)【Splay】
- java切面1.6需要的包_Java技术 AspectJ
- Android属性动画赏析,Android源码分析—属性动画的工作原理
- keepalived高可用配置注意事项
- java环境变量设置图解_Java环境变量一键配置操作方法
- 参考手册资源 百度云
- 电容或电感的电压_纯电阻、纯电感和纯电容电路
- LabVIEW心率监测装置
- UE4基础知识总结(一)
- 短信验证码接收app必须注意的那些事
- AJAX框架眼镜穿搭夏天,30度的夏天,男生应该如何穿搭?看这9种时尚组合!
- K12在线教育行业和产品分析报告
- PLC通讯实现-C#实现西门子PLC以太网通讯Sharp7(六)
- Spring Cloud 异常“ Caused by: java.net.UnknownHostException: discovery.host ”
- Jmeter接口测试+压力测试
热门文章
- 矩阵分解 SVD 和 CUR的区别
- 论文阅读 (58):Research and Implementation of Global Path Planning for Unmanned Surface Vehicle Based...
- 说说微信红包算法,为什么你总是抢的那么少?
- Retrofit学习
- 20181212股票复盘
- 闲鱼是如何实践一套完整的埋点自动化验证方案的?
- 全面认识Scratch少儿编程
- “工赋”三问:从青岛到德阳,卡奥斯如何实现跨区域复制?
- PERT(计划评审技术Program Evaluation an Review Technique)
- 【google翻译】使用Ola Hallengren的脚本更新统计数据