美文网首页
AES 加密解密,小工具

AES 加密解密,小工具

作者: 代瑶 | 来源:发表于2021-03-04 19:50 被阅读0次

    package com.gksb.common.util;

    import sun.misc.BASE64Decoder;
    import sun.misc.BASE64Encoder;

    import javax.crypto.*;
    import javax.crypto.spec.SecretKeySpec;

    public class DSMEncryptUtil {
    //偏移量
    // public static final String VIPARA = "1234567876543210"; //AES 为16bytes. DES 为8bytes

    //编码方式
    public static final String CODE_TYPE = "UTF-8";
    //public static final String CODE_TYPE = "GBK";
    
    //填充类型
    public static final String AES_TYPE = "AES/ECB/PKCS5Padding";
    
    //public static final String AES_TYPE = "AES/ECB/PKCS7Padding";
    //此类型 加密内容,密钥必须为16字节的倍数位,否则抛异常,需要字节补全再进行加密
    //public static final String AES_TYPE = "AES/ECB/NoPadding";
    //java 不支持ZeroPadding
    //public static final String AES_TYPE = "AES/CBC/ZeroPadding";
    
    //私钥
    private static final String AES_KEY = "shiliuweishudezi";   //AES固定格式为128/192/256 bits.即:16/24/32bytes。DES固定格式为128bits,即8bytes。
    
    /**
     * 加密
     *
     * @param cleartext
     * @return
     */
    public static String encrypt(String cleartext) {
        //加密方式: AES128(CBC/PKCS5Padding) + Base64, 私钥:1111222233334444
        try {
    

    // IvParameterSpec zeroIv = new IvParameterSpec(VIPARA.getBytes());
    //两个参数,第一个为私钥字节数组, 第二个为加密方式 AES或者DES
    SecretKeySpec key = new SecretKeySpec(AES_KEY.getBytes(), "AES");
    //实例化加密类,参数为加密方式,要写全
    Cipher cipher = Cipher.getInstance(AES_TYPE); //PKCS5Padding比PKCS7Padding效率高,PKCS7Padding可支持IOS加解密
    //初始化,此方法可以采用三种方式,按加密算法要求来添加。(1)无第三个参数(2)第三个参数为SecureRandom random = new SecureRandom();中random对象,随机数。(AES不可采用这种方法)(3)采用此代码中的IVParameterSpec
    //加密时使用:ENCRYPT_MODE; 解密时使用:DECRYPT_MODE;
    cipher.init(Cipher.ENCRYPT_MODE, key); //CBC类型的可以在第三个参数传递偏移量zeroIv,ECB没有偏移量
    //加密操作,返回加密后的字节数组,然后需要编码。主要编解码方式有Base64, HEX, UUE,7bit等等。此处看服务器需要什么编码方式
    byte[] encryptedData = cipher.doFinal(cleartext.getBytes(CODE_TYPE));

            return new BASE64Encoder().encode(encryptedData);
        } catch (Exception e) {
            e.printStackTrace();
            return "";
        }
    }
    
    /**
     * 解密
     *
     * @param encrypted
     * @return
     */
    public static String decrypt(String encrypted) {
        try {
            byte[] byteMi = new BASE64Decoder().decodeBuffer(encrypted);
    

    // IvParameterSpec zeroIv = new IvParameterSpec(VIPARA.getBytes());
    SecretKeySpec key = new SecretKeySpec(
    AES_KEY.getBytes(), "AES");
    Cipher cipher = Cipher.getInstance(AES_TYPE);
    //与加密时不同MODE:Cipher.DECRYPT_MODE
    cipher.init(Cipher.DECRYPT_MODE, key); //CBC类型的可以在第三个参数传递偏移量zeroIv,ECB没有偏移量
    byte[] decryptedData = cipher.doFinal(byteMi);
    return new String(decryptedData, CODE_TYPE);
    } catch (Exception e) {
    e.printStackTrace();
    return "";
    }
    }

    }

    相关文章

      网友评论

          本文标题:AES 加密解密,小工具

          本文链接:https://www.haomeiwen.com/subject/ybokqltx.html