1

这节课 :

import org.jasypt.util.text.BasicTextEncryptor;

    public class TestSame {

        public static void main(String args[]){

            BasicTextEncryptor textEncryptor = new BasicTextEncryptor();
            textEncryptor.setPassword("test");

            System.out.println(textEncryptor.encrypt("test"));
            System.out.println(textEncryptor.encrypt("test"));

            System.out.println(textEncryptor.decrypt("Nv4nMcuVwsvWVuYD7Av44Q=="));
            System.out.println(textEncryptor.decrypt("bjU82X18p9gAivwomA+NpQ=="));

        }

    }

生成此输出:

n3G0M4YH8QjPU+YMYsfTmw==
ftokGN7dMKyLtKBaim2RTQ==
test
test

为什么密文不同?解密的文本是相同的,那么由于每个加密的文本不同,如何解密密码?

我希望使用相同密码和相同加密的相同文本会生成相同的加密文本,但情况似乎并非如此?

4

1 回答 1

6

从文档中

如果使用随机盐生成器,相同消息的两个加密结果将始终不同(随机盐重合的情况除外)。这可以通过一次难以对数据集进行蛮力攻击并迫使攻击者对每个单独的加密数据片段执行蛮力攻击来加强安全性。

于 2013-11-27T12:00:02.340 回答