可逆的加密演算法
⑴ 求一個用java編寫的可逆的加密演算法程序,自己寫的小程序也行。
public class mySecurity {
private static KeyGenerator keygen ;
private static SecretKey secretKey;
private static Cipher cipher;
private static mySecurity security = null;
private mySecurity(){
}
public static mySecurity getInstance() throws Exception{
if(security == null){
security = new mySecurity();
keygen = KeyGenerator.getInstance("AES");
secretKey = keygen.generateKey();
cipher =Cipher.getInstance("AES");
}
return security;
}
//加密
public String encrypt(String str) throws Exception{
cipher.init(Cipher.ENCRYPT_MODE,secretKey);
byte [] src = str.getBytes(); byte [] enc = cipher.doFinal(src);
return parseByte2HexStr(enc); }
//解密
public String decrypt(String str) throws Exception{
cipher.init(Cipher.DECRYPT_MODE,secretKey);
byte[] enc = parseHexStr2Byte(str); byte [] dec = cipher.doFinal(enc);
return new String(dec); }
/**將16進制轉換為二進制
* @param hexStr
* @return
*/
public static byte[] parseHexStr2Byte(String hexStr) {
if (hexStr.length() < 1)
return null;
byte[] result = new byte[hexStr.length()/2];
for (int i = 0;i< hexStr.length()/2; i++) {
int high = Integer.parseInt(hexStr.substring(i*2, i*2+1), 16);
int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), 16);
result[i] = (byte) (high * 16 + low);
}
return result;
}
/**將二進制轉換成16進制
* @param buf
* @return
*/
public static String parseByte2HexStr(byte buf[]) {
StringBuffer sb = new StringBuffer();
for (int i = 0; i < buf.length; i++) {
String hex = Integer.toHexString(buf[i] & 0xFF);
if (hex.length() == 1) {
hex = '0' + hex;
}
sb.append(hex.toUpperCase());
}
return sb.toString();
}
public static void main(String[] args) throws Exception{
String str = "abc haha 我";
String ss = mySecurity.getInstance().encrypt(str) ;
System.out.println(ss);
System.out.println(mySecurity.getInstance().decrypt(ss));
}
}
⑵ 什麼是AES加密詳解AES加密演算法原理流程
在密碼學領域,加密演算法主要分為兩大類:雙向加密和單向加密。單向加密如MD5、SHA等,屬於摘要演算法,具有不可逆性。而雙向加密包括對稱加密和非對稱加密,其中對稱加密包括AES加密、DES加密等,這類加密是可逆的,且存在密文密鑰。AES演算法作為DES演算法的替代者,是目前應用最廣泛的加密演算法之一。以下將詳細介紹AES加密演算法及其原理和流程。
什麼是AES加密演算法?AES,全稱為高級加密標准,也稱為Rijndael加密法,是美國聯邦政府採用的一種區塊加密標准。它被廣泛應用於全球,成為對稱密鑰加密中最流行的演算法之一。AES支持三種密鑰長度:128位、192位和256位。
AES加密演算法原理主要包括兩個方面:密鑰和填充。
密鑰是AES演算法實現加密和解密的核心。對稱加密演算法之所以對稱,是因為加密和解密過程都需要使用同一個密鑰。AES支持三種密鑰長度:128位、192位和256位。通常所說的AES128、AES192、AES256,實際上指的是AES演算法對不同長度密鑰的使用。
填充是為了滿足AES分組加密的特性。AES演算法在對明文加密時,會將明文拆分成一個個獨立的明文塊,每個塊長度為128bit。經過加密器處理後,將各個密文塊拼接在一起,形成最終的加密結果。如果明文長度不是128bit的整數倍,需要對明文塊進行填充。常見的填充模式包括NoPadding、PKCS5Padding(默認)和ISO10126Padding。
AES演算法流程涉及四種操作:位元組替代、行移位、列混淆和輪密鑰加。加解密演算法的每一步都對應逆操作,且加解密操作的順序相反。通過這些操作,保證了演算法的正確性。在加解密過程中,每輪的密鑰由種子密鑰經過密鑰擴展演算法得到。演算法中的明文、密文和輪子密鑰均以4x4矩陣表示。
總而言之,AES是新一代加密標准,具有128bit的分組長度,支持128、192和256比特的密鑰長度,是目前最流行的加密演算法之一。本文介紹了AES加密演算法的原理和流程,更多關於加密演算法的內容,後期將繼續更新。