对称加密技术 - PBE系列

37 篇文章 0 订阅
13 篇文章 0 订阅

PBE加密跳出了DES和AES的加密模式,综合对称加密、信息摘要算法的优势,形成了一个对称加密的特例。其实PBE加密并不是独创了一个新的算法,而是先使用MD(SHA)系列算法将口令和slat计算出一个key出来,然后用这个key作为DES(AES)的加解密key,这样DES和AES的key不便于记忆且需要计算的问题就解决了。

算法特点

PBE算法,全称 password based encrytpion,基于口令的加密,该算法不是新的算法,是融合算法,主要步骤如下:

  • 首先用户输入口令,然后根据slat,采用信息摘要算法(MD5、SHA-256等)计算一个固定长度的摘要出来;
  • 将该固定长度的摘要转换为对称加密算法(DES、AES)要求长度的密钥key;
  • 使用key并采用对称加密算法对数据进行加密。

PBE没有密钥的概念,PBE使用口令替代了密钥。PBE算法是信息摘要算法和对称加密算法的融合,比如PBEWithMD5AndDES是MD5和DES的结合,类似的也可以反推。

口令和密钥的区别

  • 口令:一般与用户名对应,是某个用户自己编织的便于记忆的一串单词、数字、汉字字符,口令的特点容易被记忆,也容易泄露和被盗取,容易被社会工程学,暴力破解,撞库等方式获取。
  • 密钥:是经过加密算法计算出来的,密钥一般不容易记忆,不容易被破解,而且很多时候密钥是作为算法的参数出现的,算法对于密钥长度也是有要求的,因为加密算法的作用就是利用密钥来扰乱明文顺序和含有的
  • NOTE:口令不能代替密钥,但是可以用信息摘要算法将口令转换为密钥;

Java中的算法实现

Java支持的PBE算法列表如下:

算法密钥长度密码长度默认值工作模式填充方式
PBEWithMD5AndDES5656CBCPKCS5Padding
PBEWithMD5AndTripleDES112、168168CBCPKCS5Padding
PBEWithSHA1AndDESede112、168168CBCPKCS5Padding
PBEWithMD5AndRC2_4040到1024(8的倍数)128CBCPKCS5Padding

可以看到Java支持的PUB算法大部分是基于DES的,没有AES的,所以想要使用PBE可以使用Bouncy Castle开源包。

示例代码

使用char[]构建密钥,是因为char[]是不能序列化的,所以只能驻留在内存中。而String是可以序列化的,而且不一定能及时回收,容易被分析攻击;

public class PBETest {

    // 迭代测试
    private static final int ITERATION_COUNT = 100;
    // 使用的算法
    private static final String ALGORITHM = "PBEWithMD5AndDes";

    public static void main(String[] args) throws Exception {
        // 产生salt
        byte[] salt = generateSalt();
        System.out.println(Base64.getEncoder().encodeToString(salt));

        String pwd = "password";
        String input = "加密我";

        byte[] encryptDatat = encrypt(pwd.toCharArray(), salt, input.getBytes());
        System.out.println(HexBin.encode(encryptDatat));

        byte[] rs = decrypt(pwd.toCharArray(), salt, encryptDatat);
        System.out.println(new String(rs));

    }

    /**
     * 产生salt,可以产生一次,可以每次都产生一个,使用特殊方式传递给对方<br>
     * 可以在用户注册的时候产生一个,然后save到db中
     * 
     * @return
     */
    public static byte[] generateSalt() {
        SecureRandom random = new SecureRandom();
        return random.generateSeed(8);
    }

    /**
     * 转换为key<br>
     * PBE算法需要使用特殊的KeySpec,这里不输入byte[]输入char[]
     * 
     * @param pwd
     * @return
     * @throws Exception
     */
    public static Key getKey(char[] pwd) throws Exception {
        PBEKeySpec keySpec = new PBEKeySpec(pwd);
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
        return keyFactory.generateSecret(keySpec);
    }

    /**
     * 加密数据
     * 
     * @param pwd
     * @param salt
     * @param data
     * @return
     * @throws Exception
     */
    public static byte[] encrypt(char[] pwd, byte[] salt, byte[] data) throws Exception {
        PBEParameterSpec paramSpec = new PBEParameterSpec(salt, ITERATION_COUNT);
        Cipher cipher = Cipher.getInstance(ALGORITHM);
        Key key = getKey(pwd);
        cipher.init(Cipher.ENCRYPT_MODE, key, paramSpec);
        return cipher.doFinal(data);
    }

    /**
     * 解密数据
     * 
     * @param pwd
     * @param salt
     * @param data
     * @return
     * @throws Exception
     */
    public static byte[] decrypt(char[] pwd, byte[] salt, byte[] data) throws Exception {
        PBEParameterSpec paramSpec = new PBEParameterSpec(salt, ITERATION_COUNT);
        Cipher cipher = Cipher.getInstance(ALGORITHM);
        Key key = getKey(pwd);
        cipher.init(Cipher.DECRYPT_MODE, key, paramSpec);
        return cipher.doFinal(data);
    }

}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值