Java使用3DES加密解密的流程
①傳入共同約定的密鑰(keyBytes)以及算法(Algorithm),來構建SecretKey密鑰對象
SecretKey deskey = new SecretKeySpec(keyBytes, Algorithm);
②根據算法實例化Cipher對象。它負責加密/解密
Cipher c1 = Cipher.getInstance(Algorithm);
③傳入加密/解密模式以及SecretKey密鑰對象,實例化Cipher對象
c1.init(Cipher.ENCRYPT_MODE, deskey);
④傳入字節數組,調用Cipher.doFinal()方法,實現加密/解密,并返回一個byte字節數組
c1.doFinal(src);
3DES案例
—SecretUtils.java(3DES加密解密的工具類)—
package my3des;
import java.io.UnsupportedEncodingException;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
/**
* SecretUtils {3DES加密解密的工具類 }
* @author William
* @date 2013-04-19
*/
public class SecretUtils {
//定義加密算法,有DES、DESede(即3DES)、Blowfish
private static final String Algorithm = “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); //生成密鑰
Cipher c1 = Cipher.getInstance(Algorithm); //實例化負責加密/解密的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);
Cipher c1 = Cipher.getInstance(Algorithm);
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 byte[24]; //聲明一個24位的字節數組,默認里面都是0
byte[] temp = keyStr.getBytes(“UTF-8”); //將字符串轉成字節數組
/*
77 * 執行數組拷貝
* System.arraycopy(源數組,從源數組哪里開始拷貝,目標數組,拷貝多少位)
*/
if(key.length 》 temp.length){
//如果temp不夠24位,則拷貝temp數組整個長度的內容到key數組中
System.arraycopy(temp, 0, key, 0, temp.length);
}else{
//如果temp大于24位,則拷貝temp數組24個長度的內容到key數組中
System.arraycopy(temp, 0, key, 0, key.length);
}
return key;
}
}
—Main.java(測試類)—
package my3des;
public class Main {
/**
* @param args
*/
public static void main(String[] args) {
String msg = “3DES加密解密案例”;
System.out.println(“【加密前】:” + msg);
//加密
byte[] secretArr = SecretUtils.encryptMode(msg.getBytes());
System.out.println(“【加密后】:” + new String(secretArr));
//解密
byte[] myMsgArr = SecretUtils.decryptMode(secretArr);
System.out.println(“【解密后】:” + new String(myMsgArr));
}
}
評論