java

public class AESUtils {
    public static final String AES_GIV   = "ASwsqwerty1uDs";//定義16爲偏移向量
    public static Log          logger    = LogFactory.getLog(AESUtils.class);
    /**
     * 加密
     * @param String ***c需要加密的參數
     * @param String sKey密鑰16位長度的String
     * @return String 加密後的數據
     */
    public static String Encrypt(String ***c, String sKey) throws Exception {
        if (sKey == null) {
            logger.warn("Key爲空null");
            return null;
        }
        // 判斷Key是否爲16位
        if (sKey.length() != 16) {
            logger.warn("Key長度不是16位");
            return null;
        }
        byte[] raw = sKey.getBytes();
        SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");// "算法/模式/補碼方式"
        IvParameterSpec iv = new IvParameterSpec(AES_GIV.getBytes());// 使用CBC模式,需要一個向量iv,可增加加密算法的強度
        cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);
        byte[] encrypted = cipher.doFinal(***c.getBytes());
        return new BASE64Encoder().encode(encrypted);// 此處使用BASE64做轉碼功能,同時能起到2次加密的作用。
    }
    /**
     * 解密
     * @param String ***c需要解密的參數
     * @param String sKey密鑰16位長度的String
     * @return String 解密後的數據
     */
    public static String Decrypt(String ***c, String sKey) throws Exception {
        try {
            // 判斷Key是否正確
            if (sKey == null) {
                logger.warn("Key爲空null");
                return null;
            }
            // 判斷Key是否爲16位
            if (sKey.length() != 16) {
                logger.warn("Key長度不是16位");
                return null;
            }
            byte[] raw = sKey.getBytes("ASCII");
            SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
            IvParameterSpec iv = new IvParameterSpec(AES_GIV.getBytes());
            cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);
            byte[] encrypted1 = new BASE64Decoder().decodeBuffer(***c);// 先用base64解密
            try {
                byte[] original = cipher.doFinal(encrypted1);
                String originalString = new String(original);
                return originalString;
            } catch (Exception e) {
                logger.error("Decrypt error", e);
                return null;
            }
        } catch (Exception e) {
            logger.error("Decrypt error", e);
            return null;
        }
    }

--------------------------測試--------------------

測試時傳密鑰和需要加解密的參數

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章