android Aes加密 解密 工具类


public class AesUtils {
    private final static String IV = ""; //你的偏移量
    private  static final String CBC_PKCS5_PADDING = "AES/CBC/PKCS5Padding";//AES是加密方式 CBC是工作模式 PKCS5Padding是填充模式
    private  static final String AES = "AES";//AES 加密
    private  static final String SHA1PRNG="SHA1PRNG";//// SHA1PRNG 强随机种子算法, 要区别4.2以上版本的调用方法,现已可以不使用
    public static final String password = ""; //你的密钥
    /**
     * 加密
     * @param cleartext 需加密字段
     * @return
     */
    public static String encrypt(String cleartext) {
        return encrypt(cleartext.getBytes());
    }

    /**
     * 加密
     * @param cleartext 需加密字段
     * @return
     */
    public static String encrypt(byte[] cleartext){
        IvParameterSpec zeroIv = new IvParameterSpec(IV.getBytes());
        SecretKeySpec key = new SecretKeySpec(password.getBytes(), AES);
        Cipher cipher = null;
        try {
            cipher = Cipher.getInstance(CBC_PKCS5_PADDING);
            cipher.init(Cipher.ENCRYPT_MODE, key, zeroIv);
            byte[] encryptedData = cipher.doFinal(cleartext);
            return new String(Base64.encode(encryptedData,Base64.DEFAULT));
        } catch (NoSuchAlgorithmException e) {
            LogUtils.e(e);
        } catch (NoSuchPaddingException e) {
            LogUtils.e(e);
        } catch (BadPaddingException e) {
            LogUtils.e(e);
        } catch (InvalidKeyException e) {
            LogUtils.e(e);
        } catch (IllegalBlockSizeException e) {
            LogUtils.e(e);
        } catch (InvalidAlgorithmParameterException e) {
            LogUtils.e(e);
        }
        return null;
    }


    /**
     * 解密
     * @param encrypted 密文
     * @return
     */
    public static String decrypt(String encrypted){
        byte[] byteMi = Base64.decode(encrypted,Base64.DEFAULT);
        IvParameterSpec zeroIv = new IvParameterSpec(IV.getBytes());
        SecretKeySpec key = new SecretKeySpec(password.getBytes(), "AES");
        Cipher cipher = null;
        try {
            cipher = Cipher.getInstance(CBC_PKCS5_PADDING);
            cipher.init(Cipher.DECRYPT_MODE, key, zeroIv);
            byte[] decryptedData = cipher.doFinal(byteMi);
            return new String(decryptedData);
        } catch (NoSuchAlgorithmException e) {
            LogUtils.e(e);
        } catch (NoSuchPaddingException e) {
            LogUtils.e(e);
        } catch (BadPaddingException e) {
            LogUtils.e(e);
        } catch (InvalidKeyException e) {
            LogUtils.e(e);
        } catch (IllegalBlockSizeException e) {
            LogUtils.e(e);
        } catch (InvalidAlgorithmParameterException e) {
            LogUtils.e(e);
        }
        return null;
    }
}

 

你可能感兴趣的:(android Aes加密 解密 工具类)