对称加密解密
加密
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");//创建密码器 参数为加密类型 (AES DES 3DES等)
byte[] raw = sKey.getBytes();//加解密双方约定的key,可根据需要密钥的长度定义,如果是128位,则sKey的长度length = 16
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");//生成密钥
IvParameterSpec iv = new IvParameterSpec(ivByte);// 使用CBC模式,需要一个向量iv,可增加加密算法的强度
cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);初始化密码器
byte[] encrypted = cipher.doFinal(sSrc.getBytes("UTF-8"));加密
解密
byte[] raw = sKey.getBytes("ASCII");//加解密双方约定的key
SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");//生成密钥
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");//创建密码器
IvParameterSpec iv = new IvParameterSpec(ivByte);// 使用CBC模式,需要一个向量iv,可增加加密算法的强度
cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);初始化密码器
byte[] encrypted1 = parseHexStr2Byte(sSrc);
byte[] original = cipher.doFinal(encrypted1);