且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

JAVA实现DES加解密实现详解

更新时间:2022-08-12 16:14:55

DES加密介绍
       DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法。DES加密算法出自IBM的研究,后来被美国***正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,24小时内即可被破解。     虽然如此,在某些简单应用中,我们还是可以使用DES加密算法,本文简单讲解DES的JAVA实现
。注意:DES加密和解密过程中,密钥长度都必须是8的倍数

packageutil;

importjava.security.SecureRandom;
importjavax.crypto.spec.DESKeySpec;
importjavax.crypto.SecretKeyFactory;
importjavax.crypto.SecretKey;
importjavax.crypto.Cipher;
publicclassDES{
publicDES(){
}
//测试
publicstaticvoidmain(Stringargs[]){
//待加密内容
Stringstr="测试内容";
//密码,长度要是8的倍数
Stringpassword=

"9588028820109132570743325311898426347857298773549468758875018579537757772163084478873699447306034466200616411960574122434059469100235892702736860872901247123456";
byte[]result=DES.encrypt(str.getBytes(),password);
System.out.println("加密后:"+newString(result));

//直接将如上内容解密
try{
byte[]decryResult=DES.decrypt(result,password);
System.out.println("解密后:"+newString(decryResult));
}catch(Exceptione1){
e1.printStackTrace();
}

}

/**
*加密
*@paramdatasourcebyte[]
*@parampasswordString
*@returnbyte[]
*/
publicstaticbyte[]encrypt(byte[]datasource,Stringpassword){
try{
SecureRandom random=new SecureRandom();
DESKeySpec desKey=new DESKeySpec(password.getBytes());
//创建一个密匙工厂,然后用它把DESKeySpec转换成
SecretKeyFactory keyFactory=SecretKeyFactory.getInstance("DES");
SecretKey securekey=keyFactory.generateSecret(desKey);
//Cipher对象实际完成加密操作
Ciphercipher=Cipher.getInstance("DES");
//用密匙初始化Cipher对象
cipher.init(Cipher.ENCRYPT_MODE,securekey,random);
//现在,获取数据并加密
//正式执行加密操作
returncipher.doFinal(datasource);
}catch(Throwablee){
e.printStackTrace();
}
returnnull;
}
/**
*解密
*@paramsrcbyte[]
*@parampasswordString
*@returnbyte[]
*@throwsException
*/
publicstaticbyte[]decrypt(byte[]src,Stringpassword)throwsException{
//DES算法要求有一个可信任的随机数源
Secure Random random=newSecureRandom();
//创建一个DESKeySpec对象
DESKeySpecdesKey=newDESKeySpec(password.getBytes());
//创建一个密匙工厂
SecretKeyFactorykeyFactory=SecretKeyFactory.getInstance("DES");
//将DESKeySpec对象转换成SecretKey对象
SecretKey securekey=keyFactory.generateSecret(desKey);
//Cipher对象实际完成解密操作
Cipher cipher=Cipher.getInstance("DES");
//用密匙初始化Cipher对象
cipher.init(Cipher.DECRYPT_MODE,securekey,random);
//真正开始解密操作
returncipher.doFinal(src);
}
}