zoukankan      html  css  js  c++  java
  • Java使用AES算法

    Java中使用AES(CBC,128位)算法加解密。一般加密后都是用一定编码格式进行传输,此处使用Base64算法进行编解码。实现及测试代码如下:

    AESUtil.java

    package gj.secure;
    
    import javax.crypto.Cipher;
    import javax.crypto.KeyGenerator;
    import javax.crypto.SecretKey;
    import javax.crypto.spec.IvParameterSpec;
    import javax.crypto.spec.SecretKeySpec;
    import java.security.Key;
    import java.security.spec.AlgorithmParameterSpec;
    import java.util.Base64;
    
    public class AESUtil {
        private static final String CIPHER_ALGORITHM_CBC = "AES/CBC/PKCS5Padding";
        private static final String KEY_ALGORITHM = "AES";
    
        public static byte[] initKey() throws Exception {
            KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);
            kg.init(128);
            SecretKey secretKey = kg.generateKey();
            return secretKey.getEncoded();
        }
    
        public static byte[] encrypt(byte[] data, byte[] key, byte[] iv) throws Exception {
            Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM_CBC);
            Key k = new SecretKeySpec(key, KEY_ALGORITHM);
            AlgorithmParameterSpec paramSpec = new IvParameterSpec(iv);
            cipher.init(Cipher.ENCRYPT_MODE, k, paramSpec);
            return cipher.doFinal(data);
        }
    
        public static byte[] decrypt(byte[] bytes, byte[] key, byte[] iv) throws Exception {
            Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM_CBC);
            Key k = new SecretKeySpec(key, KEY_ALGORITHM);
            AlgorithmParameterSpec paramSpec = new IvParameterSpec(iv);
            cipher.init(Cipher.DECRYPT_MODE, k, paramSpec);
            return cipher.doFinal(bytes);
        }
    
        public static String encodeToBase64String(String data, byte[] key, byte[] iv) throws Exception {
            return Base64.getEncoder().encodeToString(encrypt(data.getBytes(), key, iv));
        }
    
        public static String decodeFromBase64String(String data, byte[] key, byte[] iv) throws Exception {
            byte[] bytes = Base64.getDecoder().decode(data);
            return new String(decrypt(bytes, key, iv));
        }
    }
    

      

    测试代码:

    AESUtilTest.java

    package gj.secure;
    
    /**
     * created by gj on 2019-12-24 17:17
     **/
    public class AESUtilTest {
        public static void main(String[] args) throws Exception {
            byte[] key = AESUtil.initKey();
            byte[] iv = {0x01, 0x23, 0x45, 0x67, 0x89 - 0xFF, 0xAB - 0xFF, 0xCD - 0xFF, 0xEF - 0xFF,
                    0x01, 0x23, 0x45, 0x67, 0x89 - 0xFF, 0xAB - 0xFF, 0xCD - 0xFF, 0xEF - 0xFF};
            String content = "areful1997";
            String cipher = AESUtil.encodeToBase64String(content, key, iv);
            System.out.println(cipher);
    
            String plain = AESUtil.decodeFromBase64String(cipher, key, iv);
            System.out.println(plain);
        }
    }
    

      

  • 相关阅读:
    poj2452
    bnuoj16491
    1326: The contest(并查集+分组背包)
    BNUOJ-1065或运算的简单解法
    递推、规律思维题总结
    uva10160(dfs+状态压缩)
    第七章 人工智能,7.1 基于深度强化学习与自适应在线学习的搜索和推荐算法研究(作者:灵培、霹雳、哲予)
    第六章 大数据,6.3 突破传统,4k大屏的沉浸式体验(作者: 彦川、小丛)
    第六章 大数据,6.2 双11背后的大规模数据处理(作者:惠岸 朋春 谦乐)
    第六章 大数据,6.1 双11数据大屏背后的实时计算处理(作者:藏六 黄晓锋 同杰)
  • 原文地址:https://www.cnblogs.com/areful/p/10348809.html
Copyright © 2011-2022 走看看