`

java.security.NoSuchAlgorithmException: AES KeyGenerator not available

 
阅读更多
java.security.NoSuchAlgorithmException: AES KeyGenerator not available



1.需要将那个扩展jar包(bcprov-ext-jdk16-146.jar)下载地址:http://www.bouncycastle.org/latest_releases.html

2.import org.apache.commons.codec.binary.Base64要下载下面包:
http://commons.apache.org/codec/download_codec.cgi






package com.org.momo.数据库字段加解密;

import java.security.Key;
import java.security.Security;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Base64;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
/**
 * IDEA对称加密算法,java6不支持这个算法的实现,bouncycastle支持IDEA对称加密算法
 * 这是一款对称分组密码。是目前比较常用的电子邮件加密算法之一
 * 我们可以参照这个算法的实现来完成其他算法的实现:Rijndael,Serpent,Twofish等
 * @author kongqz
 * */
public class IDEACoder {
	/**
	 * 密钥算法
	 * */
	public static final String KEY_ALGORITHM="IDEA";
	
	/**
	 * 加密/解密算法/工作模式/填充方式
	 * */
	public static final String CIPHER_ALGORITHM="IDEA/ECB/ISO10126Padding";
	
	/**
	 * 
	 * 生成密钥,只有bouncycastle支持
	 * @return byte[] 二进制密钥
	 * */
	public static byte[] initkey() throws Exception{
		//加入bouncyCastle支持
		Security.addProvider(new BouncyCastleProvider());
		
		//实例化密钥生成器
		KeyGenerator kg=KeyGenerator.getInstance(KEY_ALGORITHM);
		//初始化密钥生成器,IDEA要求密钥长度为128位
		kg.init(128);
		//生成密钥
		SecretKey secretKey=kg.generateKey();
		//获取二进制密钥编码形式
		return secretKey.getEncoded();
	}
	/**
	 * 转换密钥
	 * @param key 二进制密钥
	 * @return Key 密钥
	 * */
	public static Key toKey(byte[] key) throws Exception{
		//实例化DES密钥
		//生成密钥
		SecretKey secretKey=new SecretKeySpec(key,KEY_ALGORITHM);
		return secretKey;
	}
	
	/**
	 * 加密数据
	 * @param data 待加密数据
	 * @param key 密钥
	 * @return byte[] 加密后的数据
	 * */
	public static byte[] encrypt(byte[] data,byte[] key) throws Exception{
		//加入bouncyCastle支持
		Security.addProvider(new BouncyCastleProvider());
		//还原密钥
		Key k=toKey(key);
		//实例化
		Cipher cipher=Cipher.getInstance(CIPHER_ALGORITHM);
		//初始化,设置为加密模式
		cipher.init(Cipher.ENCRYPT_MODE, k);
		//执行操作
		return cipher.doFinal(data);
	}
	/**
	 * 解密数据
	 * @param data 待解密数据
	 * @param key 密钥
	 * @return byte[] 解密后的数据
	 * */
	public static byte[] decrypt(byte[] data,byte[] key) throws Exception{
		//加入bouncyCastle支持
		Security.addProvider(new BouncyCastleProvider());
		//还原密钥
		Key k =toKey(key);
		Cipher cipher=Cipher.getInstance(CIPHER_ALGORITHM);
		//初始化,设置为解密模式
		cipher.init(Cipher.DECRYPT_MODE, k);
		//执行操作
		return cipher.doFinal(data);
	}
	/**
	 * @param args
	 * @throws Exception 
	 */
	public static void main(String[] args) throws Exception {
		String str="IDEA";
		System.out.println("原文:"+str);
		//初始化密钥
		byte[] key=IDEACoder.initkey();
		System.out.println("密钥:"+Base64.encodeBase64String(key));
		//加密数据
		byte[] data=IDEACoder.encrypt(str.getBytes(), key);
		System.out.println("加密后:"+Base64.encodeBase64String(data));
		//解密数据
		data=IDEACoder.decrypt(data, key);
		System.out.println("解密后:"+new String(data));
	}
}
//控制台输出结果:
//原文:IDEA
//密钥:TIM+ksMQUeUe6LHHBGntag==
//加密后:rRHc34j86i4=
//解密后:IDEA


参考:http://blog.csdn.net/kongqz/article/details/6287270

     http://blog.csdn.net/kongqz/article/details/6287270
分享到:
评论

相关推荐

    jsse-2.0.5.jar.zip

    java.security.NoSuchAlgorithmException: SHA1PRNG SecureRandom not available at sun.security.jca.GetInstance.getInstance(GetInstance.java:142) at java.security.SecureRandom.getInstance(SecureRandom....

    jce_policy-8.AES加密版本.zip

    Exception in thread "main" java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/ECB/PKCS7Padding https://www.codeprj.com/blog/92cdc41.html

    struts2源码解析,个人感觉很不错

    Struts2是一个流行的Java Web应用程序框架,它继承和发展了Struts1.x的一些特性,同时又采用了WebWork框架的核心技术,使得Struts2在设计理念和技术实现上都有了显著的进步。 #### Struts2与WebWork的关系 Struts2...

    org.jasig.cas.client.util.CommonUtils

    public java.security.cert.X509Certificate[] getAcceptedIssuers() { return null; } public void checkClientTrusted(java.security.cert.X509Certificate[] certs, String ...

    sunjce_provider.jar

    程序报错:Caused by: java.security.NoSuchAlgorithmException: PBKDF2WithHmacSHA256 SecretKeyFactory not available 就是缺少这个包

    数据进行sha1签名 数据防篡改

    2. 创建MessageDigest实例:使用`java.security.MessageDigest.getInstance("SHA1")`获取SHA1实例。 3. 更新数据:调用`digest.update()`方法添加要签名的数据。 4. 生成哈希值:通过`digest.digest()`方法获取哈希...

    aesjava源码-THIS-.-IS-GREAT-:////IntelliJIDEA从.class文件重新创建的源代码//(由Fernflo

    aes java源码这很棒- // // IntelliJ IDEA从.class文件重新创建的源代码//(由...导入java.security.NoSuchAlgorithmException; 导入java.security.PrivilegedAction; 导入java.security.PrivilegedActionException

    MD5加密算法:js,asp,java,jsp,jquery多种版本的md5写法

    <%@ page import="java.security.MessageDigest,java.security.NoSuchAlgorithmException" %> String str = "你的明文字符串"; try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] hashBytes ...

    RAS、Md5、 AES java加密实现

    import java.security.NoSuchAlgorithmException; public class MD5Example { public static String encrypt(String input) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] ...

    Java自带方法实现RSA加密解密

    import java.security.NoSuchAlgorithmException; import java.security.PrivateKey; import java.security.PublicKey; public class RSAKeys { public static void main(String[] args) throws ...

    java的MD5算法

    - `java.security.NoSuchAlgorithmException`:当请求特定算法名称的Provider时找不到实现该算法的Provider会抛出此异常。 - `java.io.UnsupportedEncodingException`:当请求的字符编码集不可用时抛出此异常。 ###...

    java密码加密

    import java.security.NoSuchAlgorithmException; public String encryptToMD5(String info) { try { MessageDigest md = MessageDigest.getInstance("MD5"); md.update(info.getBytes()); byte[] digestBytes ...

    Java 生成RSA密钥进行数据加密解密 支持超长字符分区

    import java.security.NoSuchAlgorithmException; import javax.crypto.Cipher; // 保存密钥到文件 public void saveKeys(PublicKey publicKey, PrivateKey privateKey, String publicKeyPath, String ...

    JAVA实现AES加密算法代码.doc

    在这个实现中,我们使用了 JAVA 的加密 API,即 java.security 包中的 Cipher 类和 KeyGenerator 类。 Cipher 类用于加密和解密数据,而 KeyGenerator 类用于生成加密密钥。 在 encrypt 方法中,我们首先使用 ...

    Java MD5 加密

    首先,我们需要导入`java.security.MessageDigest`和`java.security.NoSuchAlgorithmException`库,以处理MD5加密。 ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException;...

    创建pkcs12格式数字签名证书的Java代码

    在Java环境中,我们通常会借助第三方库如BouncyCastle来创建和处理这种格式的证书。本文将深入探讨如何使用BouncyCastle库在Java中创建PKCS12格式的数字签名证书。 首先,理解BouncyCastle库。BouncyCastle是一个...

    JAVA高手MD5加密算法底层源码完美实现

    import java.security.NoSuchAlgorithmException; public class MD5Example { public static String encrypt(String data) { try { MessageDigest md = MessageDigest.getInstance("MD5"); byte[] hashBytes = ...

    2022如何在Java处理PFX格式证书.docx

    import java.security.NoSuchAlgorithmException; import java.security.PrivateKey; import java.security.cert.Certificate; import java.security.cert.CertificateFactory; import java.security.cert.X509...

    ios push java 服务端程序

    - 在Java环境中,你需要安装Java Cryptography Extension (JCE),因为默认情况下,Java只支持128位的加密算法,而APNs需要256位。 2. **连接到APNs** - 使用Java的Socket编程,建立到APNs服务器的TCP连接。生产...

Global site tag (gtag.js) - Google Analytics