在使用Cipher类最加密的时候,如果需要大量进行加解密工作,需要避免Cipher类的大量实例化,本文用MAP记录已经实例化的Cipher,如果已经存在则不需要在实例化、避免内存浪费、导致 Cipher not initialized 错误。
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.spec.InvalidKeySpecException;
import java.util.HashMap;
import javax.crypto.Cipher;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import sun.misc.BASE64Decoder;
/**
* 解密
*/
public class DESTool {
private static String Algorithm = "DESede";// 加密算法的名称
private static Cipher c;// 密码器
//private static byte[] cipherByte;
private static SecretKey deskey;// 密钥
private static String keyString = "XXXXXXXXXXXXXXXXXXXXXXXXX";// 获得密钥的参数
private static HashMap decryptCipherMap=new HashMap();
// Logger log =Logger.getLogger(DESTool.class);
// 对base64编码的string解码成byte数组
public byte[] deBase64(String parm) throws IOException {
BASE64Decoder dec = new BASE64Decoder();
byte[] dnParm = dec.decodeBuffer(parm);
//System.out.println(dnParm.length);
//System.out.println(dnParm);
return dnParm;
}
// 把密钥参数转为byte数组
public byte[] dBase64(String parm) throws IOException {
BASE64Decoder dec = new BASE64Decoder();
byte[] dnParm = dec.decodeBuffer(parm);
return dnParm;
}
/**
* 对 Byte 数组进行解密
*
* @param buff
* 要解密的数据
* @return 返回加密后的 String
*/
public static String createDecryptor(byte[] buff)
throws NoSuchPaddingException, NoSuchAlgorithmException,
UnsupportedEncodingException {
byte[] cipherByte = buff ;
try {
cipherByte = c.doFinal(buff);
} catch (javax.crypto.BadPaddingException ex) {
ex.printStackTrace();
return null;
} catch (javax.crypto.IllegalBlockSizeException ex) {
ex.printStackTrace();
return null;
}
return (new String(cipherByte, "UTF-8"));
}
public void init(String key) throws IOException, InvalidKeyException,
InvalidKeySpecException {
byte[] dKey = dBase64(key);
try {
if(decryptCipherMap.get("keyString")==null){//判断是否已经存在实例,如果存在不在实例化。
deskey = new javax.crypto.spec.SecretKeySpec(dKey, Algorithm);
c = Cipher.getInstance(Algorithm);
c.init(Cipher.DECRYPT_MODE, deskey);// 初始化密码器,用密钥deskey,进入解密模式
decryptCipherMap.put("keyString", c);
}
} catch (NoSuchPaddingException ex) {
} catch (NoSuchAlgorithmException ex) {
}
}
/**
*
* @param strEncryption 加密字符串
* @return 返回解密后的字符串
* @throws IOException
* @throws NoSuchAlgorithmException
* @throws NoSuchPaddingException
* @throws InvalidKeySpecException
* @throws InvalidKeyException
* @throws IOException
*/
public static String decryptScore(String strEncryption)throws IOException,
NoSuchAlgorithmException, NoSuchPaddingException,
InvalidKeySpecException, InvalidKeyException, IOException{
DESTool des = new DESTool();
des.init(keyString);
byte[] dBy = des.deBase64(strEncryption);
return des.createDecryptor(dBy);
}
public static void main(String args[]) throws IOException,
NoSuchAlgorithmException, NoSuchPaddingException,
InvalidKeySpecException, InvalidKeyException, IOException {
DESTool des = new DESTool();
des.init(keyString);
//byte[] dBy = des.deBase64("1ZVasdJJco1qccDnnfQfb8QeaARxhkR6");
byte[] dBy = des.deBase64("JdTkEPNsw8E=");
String dStr = des.createDecryptor(dBy);
System.out.println("解:" + decryptScore("JdTkEPNsw8E="));
}
}
分享到:
相关推荐
Delphi 开发的AES 等对称加密解密控件 1.AES算法 AES-128-CBC、AES-192-CBC、AES-256-CBC; AES-128-CFB、AES-192-CFB、AES-256-CFB; AES-128-CFB1、AES-192-CFB1、AES-256-CFB1; AES-128-CFB8、AES-192-CFB8、...
Cipher加密解密
C++ DH密钥交换 RSA Permutation cipher keyword cipher
CIPHER加密解密等多种算法
java实现加密解密算法工具类_Cipher
des加解密算法,可加解密文件,及内存 非常好用。
两个加解密算法程序,VS2010下测试通过!
恺撒加密的python实现,CTF必备,小游戏很好,恺撒加解密(Caesar cipher)——python脚本实现
目前这个工具支持对称加密算法(AES、3DES)、非对称加密算法(RSA)、单向散列算法(MD5、SHA1、CRC32)、Base64算法等,后期还会不定时新增别的算法,在使用过程中如有问题欢迎邮件给我,我会及时优化和反馈。
可对文件,字符串加解密。 密钥为字符串自己随便添。加密文件时注意源文件和输出文件。解密字符串时需注意给源数据长度参数。
由于Java的RSA加解密一般都是用RSA/ECB/PKCS1PADDING,导致Python一般的RSA加密库的加解密结果与Java的不兼容,Python下目前能与之兼容的RSA的库目前发现的只有一个,就是m2crypto。 这个库目前的问题是在windows...
加密--Cipher加密
java和javascript加密解密,可相互加密解密,内含javascript代码和java代码,解压即用,自定义密钥
Column permutation cipher是基于置换的加密解密方式。利用本程序可实现Column permutation cipher的加密和解密。
分别使用java、php、python进行对字符串AES加解密,各个语言加解密互通,也就是java加密的,php,python可解密,其他同理。注意加密mode和填充方式要保持一致
Hi3520/15 CIPHER API参考 加密/解密 硬件方式,比软件快很多
cipher批处理查找EFS加密文件并一键解密命令,比通过属性解密要快,要方便很多。
1、实现S-DES对任意文件的加解密(命令行方式) 2、实现DES对任意文件的加解密(命令行方式) 以上两题至少选做一题。 加解密形式如下: cipher -e/-d key inputfile outputfile 说明:对于加密来说,输入文件名...
分别用C#、Java实现的RSA和DES加解密算法,包含demo源码,经实际项目验证。