(BouncyCastle错误:min可能不大于max)使用java实现El-Gamal算法

时间:2016-03-26 01:00:24

标签: java cryptography bouncycastle javax.crypto elgamal

我正在尝试在系统中实现El-Gamal加密算法。我刚刚学习了算法,并在网上查找代码以获得实现它的想法。我在互联网上找到了以下代码并给了我这个奇怪的错误:

Exception in thread "main" java.lang.IllegalArgumentException:'min' may not be greater than 'max'
    at org.bouncycastle.util.BigIntegers.createRandomInRange(Unknown Source)

    at org.bouncycastle.crypto.generators.DHKeyGeneratorHelper.calculatePrivate(Unknown Source)

    at org.bouncycastle.crypto.generators.ElGamalKeyPairGenerator.generateKeyPair(Unknown Source)
    at org.bouncycastle.jcajce.provider.asymmetric.elgamal.KeyPairGeneratorSpi.generateKeyPair(Unknown Source)
    at ElGamal.main(ElGamal.java:20)

以下是代码段:

 import java.security.Key;
 import java.security.KeyPair;
 import java.security.KeyPairGenerator;
 import java.security.SecureRandom;
 import java.security.Security;

 import javax.crypto.Cipher;

 public class ElGamal {
    public static void main(String[] args) throws Exception {
      Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());

      byte[] input = "abcdefgh".getBytes();
      Cipher cipher = Cipher.getInstance("ElGamal/None/NoPadding", "BC");
      KeyPairGenerator generator = KeyPairGenerator.getInstance("ElGamal", "BC");
      SecureRandom random = new SecureRandom();

      generator.initialize(128, random);

      KeyPair pair = generator.generateKeyPair();
      Key pubKey = pair.getPublic();
      Key privKey = pair.getPrivate();
      cipher.init(Cipher.ENCRYPT_MODE, pubKey, random);
      byte[] cipherText = cipher.doFinal(input);
      System.out.println("cipher: " + new String(cipherText));

      cipher.init(Cipher.DECRYPT_MODE, privKey);
      byte[] plainText = cipher.doFinal(cipherText);
      System.out.println("plain : " + new String(plainText));
  }
}

我对密码学非常陌生,这可能很愚蠢。如果问题太愚蠢,我很抱歉。并提前感谢。

1 个答案:

答案 0 :(得分:2)

好的伙计们。我终于找到了问题。除密钥大小外,代码没有任何问题。这主要是依赖性问题。

  1. 首先在代码中将密钥大小更改为160或更高。

  2. 从他们的网站下载并解压缩bouncyCastle API jar文件。请按照此处列出的步骤进行操作:http://www.bouncycastle.org/wiki/display/JA1/Provider+Installation

  3. 我使用了静态安装方法。

    1. 为您的JDK下载Java密码术扩展(JCE)无限强度管辖权政策文件。对于版本8,请转到此链接,并在下载和解压缩后按照自述文件中的说明进行操作。 http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html

      1. 找到Atom正在使用的Java实例的jre \ lib \ security目录。例如,此位置可能是:C:\ Program Files \ Java \ jre8 \ lib \ security。

      2. 从此目录中删除以下.jar文件:local_policy.jar和US_export_policy.jar。

      3. 将这两个文件替换为JCE Unlimited Strength Jurisdiction Policy Files下载中包含的.jar文件。

      4. 重新启动你的机器,你很高兴。

    2. P.S。在步骤(3.2)中,您可能希望首先制作本地策略文件的副本,以防发生错误。如果仍然无法正常工作,您可能需要对PC的JDK文件夹中的JRE文件夹执行相同的过程。这应该有效。