import java.io.UnsupportedEncodingException;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
/ **
* 3DES(即Triple DES)是DES向AES过渡的加密算法,目前还未被破解
* /
public class ThreeDes {
//定义加密算法,有DES,DESede(即3DES),Blowfish
private static final String算法=“DESede”;
private static final String PASSWORD_CRYPT_KEY =“2012PinganVitality075522628888ForShenZhenBelter075561869839”;
/ **
*加密方法
* @param src源数据的字节数组
* @return
* /
public static byte [] encryptMode(byte [] src){
try {
SecretKey deskey = new SecretKeySpec(
build3DesKey(PASSWORD_CRYPT_KEY),Algorithm); //生成密钥
密码c1 = Cipher.getInstance(算法); //实例化负责加密/解密的Cipher工具类
c1.init(Cipher.ENCRYPT_MODE,deskey); //
初始化为加密模式return c1.doFinal(src);
} catch(java.security.NoSuchAlgorithmException e1){
e1.printStackTrace();
} catch(javax.crypto.NoSuchPaddingException e2){
e2.printStackTrace();
} catch(java.lang.Exception e3){
e3.printStackTrace();
}
return null;
}
/ **
*解密函数
* @param src密文的字节数组
* @return
* /
public static byte [] decryptMode(byte [] src){
try {
SecretKey deskey = new SecretKeySpec(
build3DesKey(PASSWORD_CRYPT_KEY),Algorithm) ;
密码c1 = Cipher.getInstance(算法);
c1.init(Cipher.DECRYPT_MODE,deskey); //
初始化为解密模式return c1.doFinal(src);
} catch(java.security.NoSuchAlgorithmException e1){
e1.printStackTrace();
} catch(javax.crypto.NoSuchPaddingException e2){
e2.printStackTrace();
} catch(java.lang.Exception e3){
e3.printStackTrace();
}
return null;
}
/ **
*根据字符串生成密钥字节数组
* @param keyStr密钥字符串
* @return
* @throws UnsupportedEncodingException
* /
public static byte [] build3DesKey(String keyStr)
throws UnsupportedEncodingException {
byte [] key = new字节[24]; //声明一个24位的字节数组,默认里面都是0
byte [] temp = keyStr.getBytes(“UTF-8”); //将字符串转成字节数组
/ *
*执行数组拷贝System.arraycopy(源数组,从源数组哪里开始拷贝,目标数组,拷贝多少位)
* /
if(key.length> temp.length){
//如果temp不够24位,则拷贝临时数组整个长度的内容到key数组中
System.arraycopy(temp,0,key,0,temp.length);
} else {
//如果temp大于24位,则拷贝临时数组24个长度的内容到key数组中
System.arraycopy(temp,0,key,0,key.length);
}
返回键;
}
public static void main(String [] args){
String msg =“ewrtytreqmjhtrfhdfgdfhd43更丰富一壶酒近几个月一同体验23tg34gt4h54h45,如果temp不够24位,则拷贝临时数组整个长度的内容到关键数组中”;
System.out.println(“【加密前】:”+ msg);
//加密
byte [] secretArr = ThreeDes.encryptMode(msg.getBytes());
System.out.println(“【加密后】:”+ new String(secretArr));
//解密
byte [] myMsgArr = ThreeDes.decryptMode(secretArr);
System.out.println(“【解密后】:”+ new String(myMsgArr));
}
}
二、3DES
最新推荐文章于 2018-08-24 09:09:21 发布