AES の簡単な紹介:
Advanced Encryption Standard(英語: Advanced Encryption Standard、略称: AES)は、ブロック暗号化の規格です。この標準は元の DES を置き換えるために使用され、多くの関係者によって分析され、世界中で広く使用されています。AES は 128、192、および 256 ビットのキーを使用でき、比較的安全な 128 ビット ブロックでデータを暗号化および復号化します。完璧な暗号化アルゴリズムは、徹底的な方法が使用されない限り、理論的には解読できません。鍵長が 128 ビットを超える暗号化データを網羅的な方法で解読することは非現実的であり、可能性があるのは理論上のみです。統計によると、世界最速のコンピュータを使用したとしても、128 ビットのキーを使い果たすには数十億年かかり、ましてや 256 ビットのキー長の AES アルゴリズムを解読するには数十億年かかります。
AES-128-ECB ツール:
import org.apache.commons.codec.binary.Base64;
import org.springframework.util.StringUtils;
import javax.crypto.*;
import javax.crypto.spec.SecretKeySpec;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
/**
* @Author :feiyang
* @Date :Created in 5:37 PM 2018/11/28
*/
public class AesEcbUtil {
/**
* aes-128-ecb 密钥字节数
*/
private static final int AES_KEY_LENGTH = 16;
private static final String AES_KEY = "abcdefghijklmnop";
/**
* 加密
* @param content
* @return
*/
public static String encrypt(String content){
if (StringUtils.isEmpty(AES_KEY)){
return null;
}
if (AES_KEY.length() != AES_KEY_LENGTH){
return null;
}
try {
byte[] raw =AES_KEY.getBytes("utf-8");
SecretKeySpec secretKeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
byte[] encrypt = cipher.doFinal(content.getBytes("utf-8"));
return new Base64().encodeToString(encrypt);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (NoSuchPaddingException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
e.printStackTrace();
} catch (BadPaddingException e) {
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
e.printStackTrace();
}
return null;
}
/**
* 解密
* @param content
* @return
*/
public static String decrypt(String content){
if (StringUtils.isEmpty(AES_KEY)){
return null;
}
if (AES_KEY.length() != AES_KEY_LENGTH){
return null;
}
try {
byte[] raw = AES_KEY.getBytes();
SecretKeySpec secretKeySpec = new SecretKeySpec(raw, "AES");
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
byte[] decrypt = new Base64().decode(content);
byte[] original = cipher.doFinal(decrypt);
return new String(original, "utf-8");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (NoSuchPaddingException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
e.printStackTrace();
} catch (BadPaddingException e) {
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return null;
}
}