在java中加密和解密字符串

在java中加密和解密字符串,java,encryption,Java,Encryption,我对密码学一无所知。我想学习如何加密和解密文件中的文本。。。当我在网上查阅相关文章时。我有一个疑问,当对同一文本进行多次加密时,加密文本对于单个文本是否相同?谁能澄清我的疑问 public String encrypt(String str) { try { // Encode the string into bytes using utf-8 byte[] utf8 = str.getBytes("UTF8");

我对密码学一无所知。我想学习如何加密和解密文件中的文本。。。当我在网上查阅相关文章时。我有一个疑问,当对同一文本进行多次加密时,加密文本对于单个文本是否相同?谁能澄清我的疑问

    public String encrypt(String str) {
        try {
            // Encode the string into bytes using utf-8
            byte[] utf8 = str.getBytes("UTF8");

            // Encrypt
            byte[] enc = ecipher.doFinal(utf8);

            // Encode bytes to base64 to get a string
            return new sun.misc.BASE64Encoder().encode(enc);
        } catch (javax.crypto.BadPaddingException e) {
        } catch (IllegalBlockSizeException e) {
        } catch (UnsupportedEncodingException e) {
        } catch (java.io.IOException e) {
        }
        return null;
    }

    public String decrypt(String str) {
        try {
            // Decode base64 to get bytes
            byte[] dec = new sun.misc.BASE64Decoder().decodeBuffer(str);

            // Decrypt
            byte[] utf8 = dcipher.doFinal(dec);

            // Decode using utf-8
            return new String(utf8, "UTF8");
        } catch (javax.crypto.BadPaddingException e) {
        } catch (IllegalBlockSizeException e) {
        } catch (UnsupportedEncodingException e) {
        } catch (java.io.IOException e) {
        }
        return null;
    }
}
下面是一个使用该类的示例:

try {
    // Generate a temporary key. In practice, you would save this key.
    // See also Encrypting with DES Using a Pass Phrase.
    SecretKey key = KeyGenerator.getInstance("DES").generateKey();

    // Create encrypter/decrypter class
    DesEncrypter encrypter = new DesEncrypter(key);

    // Encrypt
    String encrypted = encrypter.encrypt("Don't tell anybody!");

    // Decrypt
    String decrypted = encrypter.decrypt(encrypted);
} catch (Exception e) {
}
我怀疑 加密文本将与单个文件相同 由多个用户执行加密时的文本 同一文本上的时间

这在很大程度上取决于您使用的加密算法:

  • 一些/大多数(成熟)算法的一个目标是,加密两次后,加密文本会有所不同。这样做的一个原因是,攻击者无法计算密钥,无法知道明文和加密文本的已知程度
  • 其他算法(主要是单向加密哈希)如MD5或SHA,基于这样一个事实,即每个加密/哈希的哈希文本都是相同的

当使用相同密钥加密纯文本时,加密是否相同取决于算法和协议。在密码学中有初始化向量IV:与各种密码一起使用的向量使得使用相同密钥加密的相同纯文本产生各种密码文本

我建议你在维基百科上阅读更多关于密码学的内容,布鲁斯·施奈尔和大卫·霍克的“用Java开始密码学”。最后一本书充满了使用图书馆的例子


如果您对密码学感兴趣,请参阅there is CrypTool:CrypTool是一款免费的开源电子学习应用程序,在全球范围内用于加密算法的实施和分析。

可能的副本非常感谢您的回复和指导,先生。。我将阅读那些特定的书..Pratik,get instance中的DES是什么?@user775:javax.crypto.KeyGenerator类的方法getInstance(字符串算法),返回算法的javax.crypto.KeyGenerator对象。以及一个java.security.Key,它是有效的DES算法加密密钥。字节[]enc=ecipher.doFinal(utf8)是什么;什么是byte[]utf8=dcipher.doFinal(dec)?ecipher和dcipher似乎是javax.crypto.Cipher的实例: