package com.yinhoo.ca.utils;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.util.Arrays;
import javax.crypto.Cipher;
import org.apache.commons.io.FileUtils;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.yinhoo.ca.helper.KeyPairLoader;
/**
* 用于进行文件的RSA加密
*
* @author ming.chen
* @date 2011-2-14
* @version $Revision$
*/
public class RSAUtils {
private static Logger logger = LoggerFactory.getLogger(RSAUtils.class);
private static final int ECODE_EACH_READ_SIZE = 100;
private static final int DECODE_EACH_READ_SIZE = 128;
/**
* 对文件进行RSA加密
*
* @param ip
* 要加密的客户端ip
* @param srcFilePath
* 要加密文件的完整路径
*/
public static void encryptFile(String ip, String srcFilePath) {
if (KeyPairLoader.getKeyPairByIp(ip) == null) {
logger.warn("No Encode key bind on ip:" + ip);
return;
}
File file = new File(srcFilePath);
if (!file.exists() || !file.isFile()) {
logger.warn(String.format("%s is not file.", srcFilePath));
return;
}
try {
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding", new BouncyCastleProvider());
cipher.init(Cipher.ENCRYPT_MODE, KeyPairLoader.getKeyPairByIp(ip).getPrivate());
ByteArrayOutputStream baos = new ByteArrayOutputStream();
byte[] bytes = FileUtils.readFileToByteArray(file);
for (int i = 0; i < bytes.length; i += ECODE_EACH_READ_SIZE) {
int end = i + ECODE_EACH_READ_SIZE;
byte[] toEncrypt = Arrays.copyOfRange(bytes, i, end < bytes.length ? end : bytes.length);
byte[] segment = cipher.doFinal(toEncrypt);
baos.write(segment, 0, segment.length);
}
baos.flush();
byte[] result = baos.toByteArray();
FileUtils.writeByteArrayToFile(file, result);
}
catch (Exception e) {
logger.error(String.format("Error occur when encrypt file: %s", srcFilePath), e);
}
}
/**
* 对文件进行RSA解密
*
* @param ip
* 要解密的客户端ip
* @param srcFilePath
* 要解密文件的完整路径
*/
public static void decryptFile(String ip, String srcFilePath) {
if (KeyPairLoader.getKeyPairByIp(ip) == null) {
logger.warn("No Encode key bind on ip:" + ip);
return;
}
File file = new File(srcFilePath);
if (!file.exists() || !file.isFile()) {
logger.warn(String.format("%s is not file.", srcFilePath));
return;
}
try {
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding", new BouncyCastleProvider());
cipher.init(Cipher.DECRYPT_MODE, KeyPairLoader.getKeyPairByIp(ip).getPublic());
ByteArrayOutputStream baos = new ByteArrayOutputStream();
byte[] bytes = FileUtils.readFileToByteArray(file);
for (int i = 0; i < bytes.length; i += DECODE_EACH_READ_SIZE) {
int end = i + DECODE_EACH_READ_SIZE;
byte[] toDecrypt = Arrays.copyOfRange(bytes, i, end < bytes.length ? end : bytes.length);
byte[] segment = cipher.doFinal(toDecrypt);
baos.write(segment, 0, segment.length);
}
baos.flush();
byte[] result = baos.toByteArray();
FileUtils.writeByteArrayToFile(file, result);
}
catch (Exception e) {
logger.error(String.format("Error occur when decrypt file: %s", srcFilePath), e);
}
}
}
分享到:
相关推荐
易语言 rsa加密 易语言 rsa加密易语言 rsa加密
在本压缩包中,提供了RSA加密解密的工具——PRO_TDES_RSA.exe,这是一个执行程序,能够帮助用户对文件进行加密和解密操作。结合"RSATool工具简易操作指南 .doc",用户可以详细了解如何使用这个工具来保护他们的敏感...
在本项目中,"rsa.zip_QT RSA加密算法_Qt rsa加密_qt rsa加密步骤_rsa_rsa算法 qt",开发者已经实现了RSA加密算法,并结合Qt创建了一个具有图形界面的应用,使得加密过程更为直观易用。 首先,我们来深入理解RSA...
RSA加密是一种非对称加密算法,它基于两个不同的密钥:公钥和私钥。在Java和JavaScript中实现RSA加密,对于处理较长的数据至关重要,因为这两种语言的标准库默认的RSA加密只能处理相对较小的块。这里我们将深入探讨...
"RSA加密算法实验报告.pdf" 本实验报告主要介绍了RSA加密算法的实现和原理,包括密钥对的产生、加密和解密过程、数字签名等。下面是该实验报告的详细知识点总结: 一、RSA加密算法的原理 RSA加密算法是基于大数...
本文将深入探讨RSA加密和解密的基础知识以及如何在Unity中实现这一功能。 首先,RSA加密的核心原理是基于大整数因子分解的困难性。它生成一对密钥:公钥和私钥。公钥可以公开,用于加密;而私钥必须保密,用于解密...
**C# RSA加密解密详解** 在信息安全领域,加密技术是一种至关重要的手段,用于保护数据的隐私和安全性。RSA(Rivest-Shamir-Adleman)算法是一种非对称加密算法,广泛应用于网络通信、数据存储等领域。C#作为.NET...
只要其钥匙的长度足够长,用RSA加密的信息实际上是不能被解破的。但在分布式计算和量子计算机理论日趋成熟的今天,RSA加密安全性受到了挑战。 RSA算法基于一个十分简单的数论事实:将两个大质数相乘十分容易,但是想...
POSTMAN RSA加密是一种在Postman测试工具中使用RSA加密技术的方法,主要涉及到JavaScript库Forge.js。Forge.js是一个强大的开源加密库,提供了多种加密算法,包括RSA(Rivest-Shamir-Adleman),这对于安全地传输...
C++实现RSA加密 在这里,我们将详细介绍C++实现RSA加密的知识点。 标题分析 该标题表明了这个项目的主要内容是使用C++语言实现RSA加密算法。RSA加密是一种常用的非对称加密算法,广泛应用于数据加密和身份验证等...
本资源提供了RSA加密解密的源码,适用于学习和理解RSA算法的工作原理及其实现。 首先,RSA算法的核心原理基于大数的因式分解困难性。它由三位科学家Rivest、Shamir和Adleman于1977年提出,因此得名RSA。该算法包括...
RSA加密算法是一种非对称加密技术,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,是现代密码学的基石之一。在PowerBuilder(PB)开发环境中,使用RSA算法可以实现数据的安全传输和存储。PB12.5是Power...
RSA加密是一种非对称加密算法,它在网络安全和数据保护中扮演着重要角色。在前后端交互中,RSA加密常用于保障数据传输的安全性,防止数据在传输过程中被窃取或篡改。以下是对RSA加密及其在前后端交互中应用的详细...
RSA加密解密C#实现调用实例 public string RSAEncrypt(string xmlPublicKey, string m_strEncryptString) { try { byte[] PlainTextBArray; byte[] CypherTextBArray; string Result; System.Security....
RSA加密算法是公钥密码学领域的一个里程碑,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因此得名RSA。它是一种非对称加密算法,即加密和解密使用不同的密钥,极大地提高了安全性。在C语言中实现RSA...
10. **源代码与实践**:提供的RAR文件可能包含RSA加密和解密的源代码及可执行文件,这对于学习密码学理论和实践非常有价值。通过阅读和运行这些代码,可以深入理解RSA的工作机制。 总之,RSA加密算法是现代密码学的...
* RSA加密解密:私钥解密,公钥加密。 * RSA数字签名-俗称加签验签:私钥加签,公钥验签。 * RSA加密解密:私钥解密,公钥加密。 * RSA数字签名-俗称加签验签:私钥加签,公钥验签。 * RSA加密解密:私钥...
RSA加密是一种非对称加密算法,它在网络安全和数据保护领域广泛应用。该算法基于大整数因子分解的困难性,即找到两个大素数的乘积的因数是非常困难的。这种特性使得RSA成为一种安全的数据加密手段,常用于网络传输中...
1. **RSA加密原理**:RSA算法基于欧拉定理和费马小定理,通过选取两个大素数p和q生成一个大合数n(即p*q),然后计算φ(n)=(p-1)*(q-1),选择一个与φ(n)互质的整数e作为公钥的指数,最后计算d作为私钥的指数,使得e...
Java RSA加密技术是一种广泛应用于网络通信安全中的非对称加密算法,主要特点是公钥和私钥成对出现,其中公钥用于加密,私钥用于解密。这种加密方式的安全性较高,因为即使加密数据被截获,没有相应的私钥也无法解密...