BouncyCastle是一个开源的加解密解决方案,主页在http://www.bouncycastle.org/,下面写一个工具类对String加密和解密
/**
* use bouncycastle to AES encrypt
*/
public class AESUtils {
private static final AESUtils instance = new AESUtils();
byte[] iv = { 0x38, 0x37, 0x36, 0x35, 0x34, 0x33, 0x32, 0x31, 0x38, 0x37,
0x36, 0x35, 0x34, 0x33, 0x32, 0x31 };
byte[] keybytes = { 0x70, 0x2F, 0x17, 0x7F, 0x6C, 0x3A, 0x22, 0x11, 0x3F,
0x44, 0x5A, 0x66, 0x77, 0x1A, 0x12, 0x1C };
private AESUtils() {
}
public static AESUtils getInstance() {
return instance;
}
private Key key;
private byte[] enc;
public String encrypt(String msg) {
String str;
try {
Security.addProvider(new BouncyCastleProvider());
key = new SecretKeySpec(keybytes, "AES");
Cipher in = Cipher.getInstance("AES/CBC/PKCS7Padding", "BC");
in.init(Cipher.ENCRYPT_MODE, key, new IvParameterSpec(iv));
enc = in.doFinal(msg.getBytes());
str = new String(Hex.encode(enc));
return str;
} catch (InvalidKeyException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (NoSuchProviderException e) {
e.printStackTrace();
} catch (NoSuchPaddingException e) {
e.printStackTrace();
} catch (InvalidAlgorithmParameterException e) {
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
e.printStackTrace();
} catch (BadPaddingException e) {
e.printStackTrace();
}
return null;
}
public String decrypt(byte[] msg) {
String str;
try {
Security.addProvider(new BouncyCastleProvider());
key = new SecretKeySpec(keybytes, "AES");
Cipher out = Cipher.getInstance("AES/CBC/PKCS7Padding", "BC");
out.init(Cipher.DECRYPT_MODE, key, new IvParameterSpec(iv));
byte[] dec = out.doFinal(msg);
str = new String(dec);
return str;
} catch (InvalidKeyException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (NoSuchProviderException e) {
e.printStackTrace();
} catch (NoSuchPaddingException e) {
e.printStackTrace();
} catch (InvalidAlgorithmParameterException e) {
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
e.printStackTrace();
} catch (BadPaddingException e) {
e.printStackTrace();
}
return null;
}
}
分享到:
相关推荐
- **添加依赖**:在Java项目中,需要将`bouncycastle.jar`添加到项目的类路径中,通常可以通过Maven或Gradle的依赖管理来实现。 - **初始化提供者**:为了使用Bouncy Castle提供的服务,需要在Java安全配置中注册...
bouncycastle的加密软件包开发 (Bouncy Castle Crypto package) 是加密算法的一个JAVA实现
**Bouncy Castle 加密开源组件API Java Release 1.46** 是一个广泛使用的加密库,尤其在Java开发中占据重要地位。Bouncy Castle 提供了丰富的加密算法、密钥生成器、证书处理以及PKI(Public Key Infrastructure,...
非对称加密使用一对公钥和私钥,公钥用于加密,私钥用于解密。常见的非对称加密算法有 RSA、DSA(Digital Signature Algorithm)和 ECC(Elliptic Curve Cryptography)。Bouncy Castle 支持这些算法,使得在 Java ...
- **数据加密和解密**:应用内的敏感数据存储,例如用户密码,可以使用BouncyCastle提供的加密算法进行保护,增加数据的安全性。 - **数字签名和验签**:在Android应用中,BouncyCastle可用于创建和验证文件或数据...
import org.bouncycastle.jce.provider.BouncyCastleProvider; // 添加Bouncy Castle Provider Security.addProvider(new BouncyCastleProvider()); // 生成密钥对 KeyPairGenerator keyGen = ...
2. **数据加密**:使用公钥对原始数据进行加密。 3. **数据传输**:将加密后的数据发送给接收方。 4. **数据解密**:接收方使用私钥对加密数据进行解密。 **总结** Bouncy Castle Crypto APIs作为强大的加密库,极...
Bouncy Castle还提供了一个名为BCrypt的模块,允许Java代码与OpenSSL库进行交互,扩展了Java在加密领域的功能。 **SSL/TLS协议** Bouncy Castle包含一个称为JSSE(Java Secure Socket Extension)的实现,它可以...
BouncyCastle是一个强大的开源加密库,它支持多种加密算法和标准,包括PKCS#7(也称为CMS,Cryptographic Message Syntax)。 PKCS#7是一种标准格式,用于打包和加密数字签名、证书和数据。它允许在一个单一的结构...
在信息技术领域,加密库是保障数据安全的重要工具,而BouncyCastle.Crypto.dll就是这样一个强大的加密库,尤其在.NET框架下广泛被开发者所使用。BouncyCastle项目,作为一个开源的Java和.NET加密API,提供了丰富的...
1. **对称加密**:对称加密使用相同的密钥进行加密和解密,例如AES(高级加密标准)。Bouncy Castle提供了AES的多种模式(如ECB、CBC、CFB、OFB和CTR),每种模式都有其特定的适用场景和安全特性。 2. **非对称加密...
BouncyCastle库是Java和.NET平台上广泛使用的加密库之一,而"BouncyCastle.Crypto.dll"正是.NET环境中实现该库的核心组件。本文将深入探讨BouncyCastle.Crypto.dll的功能、特点以及其在.NET开发中的应用。 Bouncy...
在IT领域,尤其是在网络安全...总之,使用C#和BouncyCastle实现带原文数据的PKCS#7签名是一项重要的安全任务,涉及了加密、解密、签名和验证等多个环节。理解并正确应用这些知识点对于开发安全的网络应用程序至关重要。
**BouncyCastle.Crypto.dll** 是一个非常重要的组件,尤其对于使用C#进行加密和解密操作的开发者来说。这个库是BouncyCastle项目的一部分,它是一个开源的密码学API,支持多种加密算法和标准,如RSA、AES、DES、SHA...
BouncyCastle,作为Java和.NET平台上广泛使用的开源加密库,为开发者提供了丰富的加密算法、密码学标准接口以及证书处理功能。这份“BouncyCastle1.59帮助文档”是针对该版本的详尽指南,包含了完整的API参考和使用...
接下来,我们将详细介绍如何使用BouncyCastle.Crypto库在C#中实现这些算法: **1. 引入库和配置环境** 在C#项目中,你需要通过NuGet包管理器或手动添加引用来引入BouncyCastle库。确保安装的是1.8.10版本。 ```...
7. **轻量级加密API (Lightweight API)**:对于资源有限的环境,BouncyCastle 提供了一个轻量级的加密API,以降低内存和CPU的使用。 **文件 `BouncyCastle.Crypto.dll`** 是BouncyCastle库的动态链接库文件,包含...