`
fokman
  • 浏览: 242194 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

使用bouncycastle进行加密

 
阅读更多

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;
	}
}

 

分享到:
评论

相关推荐

    bouncycastle 加密工具包

    - **添加依赖**:在Java项目中,需要将`bouncycastle.jar`添加到项目的类路径中,通常可以通过Maven或Gradle的依赖管理来实现。 - **初始化提供者**:为了使用Bouncy Castle提供的服务,需要在Java安全配置中注册...

    bouncycastle的加密软件包开发文档

    bouncycastle的加密软件包开发 (Bouncy Castle Crypto package) 是加密算法的一个JAVA实现

    Bouncy Castle 加密开源组件API Java Release 1.46

    **Bouncy Castle 加密开源组件API Java Release 1.46** 是一个广泛使用的加密库,尤其在Java开发中占据重要地位。Bouncy Castle 提供了丰富的加密算法、密钥生成器、证书处理以及PKI(Public Key Infrastructure,...

    org.bouncycastle 加密算法包 最新1.69版

    非对称加密使用一对公钥和私钥,公钥用于加密,私钥用于解密。常见的非对称加密算法有 RSA、DSA(Digital Signature Algorithm)和 ECC(Elliptic Curve Cryptography)。Bouncy Castle 支持这些算法,使得在 Java ...

    BouncyCastle依赖.zip

    - **数据加密和解密**:应用内的敏感数据存储,例如用户密码,可以使用BouncyCastle提供的加密算法进行保护,增加数据的安全性。 - **数字签名和验签**:在Android应用中,BouncyCastle可用于创建和验证文件或数据...

    java使用bouncycastle实现椭圆曲线(ECC)双向加密解密

    import org.bouncycastle.jce.provider.BouncyCastleProvider; // 添加Bouncy Castle Provider Security.addProvider(new BouncyCastleProvider()); // 生成密钥对 KeyPairGenerator keyGen = ...

    开源加密库Bouncy Castle Crypto APIs (RSA加密)

    2. **数据加密**:使用公钥对原始数据进行加密。 3. **数据传输**:将加密后的数据发送给接收方。 4. **数据解密**:接收方使用私钥对加密数据进行解密。 **总结** Bouncy Castle Crypto APIs作为强大的加密库,极...

    bouncycastle jar包

    Bouncy Castle还提供了一个名为BCrypt的模块,允许Java代码与OpenSSL库进行交互,扩展了Java在加密领域的功能。 **SSL/TLS协议** Bouncy Castle包含一个称为JSSE(Java Secure Socket Extension)的实现,它可以...

    C# BouncyCastle实现带原文数据PKCS#7 签名、验签

    BouncyCastle是一个强大的开源加密库,它支持多种加密算法和标准,包括PKCS#7(也称为CMS,Cryptographic Message Syntax)。 PKCS#7是一种标准格式,用于打包和加密数字签名、证书和数据。它允许在一个单一的结构...

    BouncyCastle.Crypto.rar

    在信息技术领域,加密库是保障数据安全的重要工具,而BouncyCastle.Crypto.dll就是这样一个强大的加密库,尤其在.NET框架下广泛被开发者所使用。BouncyCastle项目,作为一个开源的Java和.NET加密API,提供了丰富的...

    BouncyCastle.dll C#依赖工具,用作数据的加解密辅助类

    1. **对称加密**:对称加密使用相同的密钥进行加密和解密,例如AES(高级加密标准)。Bouncy Castle提供了AES的多种模式(如ECB、CBC、CFB、OFB和CTR),每种模式都有其特定的适用场景和安全特性。 2. **非对称加密...

    BouncyCastle.Crypto.dll

    BouncyCastle库是Java和.NET平台上广泛使用的加密库之一,而"BouncyCastle.Crypto.dll"正是.NET环境中实现该库的核心组件。本文将深入探讨BouncyCastle.Crypto.dll的功能、特点以及其在.NET开发中的应用。 Bouncy...

    C# BouncyCastle实现带原文数据PKCS#7 签名

    在IT领域,尤其是在网络安全...总之,使用C#和BouncyCastle实现带原文数据的PKCS#7签名是一项重要的安全任务,涉及了加密、解密、签名和验证等多个环节。理解并正确应用这些知识点对于开发安全的网络应用程序至关重要。

    BouncyCastle.Crypto.dll 版本1.8.6 C#语言

    **BouncyCastle.Crypto.dll** 是一个非常重要的组件,尤其对于使用C#进行加密和解密操作的开发者来说。这个库是BouncyCastle项目的一部分,它是一个开源的密码学API,支持多种加密算法和标准,如RSA、AES、DES、SHA...

    bouncycastle1.59 帮助文档(包含html源文件制作工具)

    BouncyCastle,作为Java和.NET平台上广泛使用的开源加密库,为开发者提供了丰富的加密算法、密码学标准接口以及证书处理功能。这份“BouncyCastle1.59帮助文档”是针对该版本的详尽指南,包含了完整的API参考和使用...

    C# 基于BouncyCastle.Crypto 1.8.10 实现国密算法,SM2,SM3,SM4(加签解签,加密解密)

    接下来,我们将详细介绍如何使用BouncyCastle.Crypto库在C#中实现这些算法: **1. 引入库和配置环境** 在C#项目中,你需要通过NuGet包管理器或手动添加引用来引入BouncyCastle库。确保安装的是1.8.10版本。 ```...

    BouncyCastle.Crypto.dll 版本1.8.1

    7. **轻量级加密API (Lightweight API)**:对于资源有限的环境,BouncyCastle 提供了一个轻量级的加密API,以降低内存和CPU的使用。 **文件 `BouncyCastle.Crypto.dll`** 是BouncyCastle库的动态链接库文件,包含...

Global site tag (gtag.js) - Google Analytics