- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在系统中实现 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));
}
}
我对密码学很陌生,这可能很愚蠢。如果问题太愚蠢,我很抱歉。提前致谢。
最佳答案
大家好。我终于发现问题了。除了 key 大小之外,代码没有任何问题。这主要是一个依赖问题。
首先在代码中将 key 大小更改为 160 或更大。
从其网站下载并提取 bouncyCaSTLe API jar 文件。请按照此处列出的程序进行操作:http://www.bouncycastle.org/wiki/display/JA1/Provider+Installation
我使用的是静态安装方式。
下载适用于您的 JDK 的 Java 加密扩展 (JCE) 无限强度管辖策略文件。对于版本 8,请访问此链接,并在下载并解压后按照自述文件中的说明进行操作。 http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html
找到 Atom 正在使用的 Java 实例的 jre\lib\security 目录。例如,此位置可能是:C:\Program Files\Java\jre8\lib\security。
从此目录中删除以下 .jar 文件:local_policy.jar 和 US_export_policy.jar。
将这两个文件替换为 JCE Unlimited Strength Jurisdiction Policy Files 下载中包含的 .jar 文件。
重新启动您的计算机即可开始。
附注在步骤 (3.2) 中,您可能需要首先复制本地策略文件,以防发生错误。如果仍然不起作用,您可能需要对 PC 的 JDK 文件夹中的 JRE 文件夹执行相同的过程。这应该可以让它工作。
关于java - (BouncyCasSTLe 错误 : min may not be greater than max ) implementation of El-Gamal algorithm using java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36230412/
我正在尝试计算公钥的哈希值以匹配 ApplePay 提供给我的内容。我无法让 C# 中的 BouncyCaSTLe 为我提供正确格式的公钥,以便我可以对它进行哈希处理。然而,我正在移植的 Java 版
缩写 UBER 是什么意思?我知道 UBER 是 BouncyCaSTLe-Keystore 等,但我不知道缩写是什么意思。 谢谢 最佳答案 我认为这是对德语单词“Über”(over 或 super
我必须使用以下参数创建大量签名,并且使用以下代码,使用 Intel Core i5-6500 CPU 创建签名需要大约 10 毫秒。 在普通 PC 上使用这些参数创建签名大约需要 10 毫秒,这正常吗
我目前在让 BouncyCaSTLe 正常工作时遇到一些困难。这几天一直在搜索这个问题,所以我希望你能提供任何有用的见解。 这是设置。 Android 客户端使用 REST 协议(protocol)向
我有使用 BouncyCaSTLe 的 C# 代码 var jsonToSend = "{\"Number\":\"string\",\"Name\":\"string\",\"Nam
我想在 PHP 中使用 OpenSSL(或 cli linux OpenSSL)对内容进行签名。 BouncyCaSTLe 在 Java 中生成的签名: ContentInfo con
我正在创建一个证书分发系统来跟踪客户和其他内容。 发生的情况是: 客户端向服务器发送 CSR 服务器检查并签署证书 服务器将签名证书发送给客户端 客户将签名证书和私钥放入 Windows 存储区。 所
我正在尝试验证特定消息是否使用来 self 自己的信任 anchor 识别的实体证书的有效签名进行签名。我正在这样做: public static boolean isValid(CMSSignedD
因此,我们最近将 Centos 服务器上的 Java 从 java-1.8.0- 更新为 java-1.8.0-openjdk-1.8.0.121-0.b13.el7_3.x86_64/ openjd
我正在尝试使用 Java 中的 iTextPDF 从签名的 PDF 中提取数字签名数据。我的代码是: PdfReader reader = new PdfReader(is); AcroFields
我们最近升级了 BouncyCaSTLe .jar 文件以使用最新的可用版本,并一直致力于将它们实现到我们现有的代码中。 在测试加密方法时,我们发现创建的文件缺少“END PGP MESSAGE”结束
我已经安装了 BouncyCaSTLe.NetCore 包来创建自签名证书,但我找不到 CryptoApiRandomGenerator 类。 正常吗?如果是,替代品是什么? 最佳答案 您可以实现自己
我正在 IBM WebSphere 环境中实现一些 iText7.1.11 java 代码,在部署 WebSphere 时,它出错了,因为它需要一些 BouncycaSTLe JAR。根据 pom
将 PEMKeyPair 转换为 KeyPair 时在 Android 上出现异常: org.bouncycastle.openssl.PEMException: unable to convert
我正在尝试在系统中实现 El-Gamal 加密算法。我刚刚了解了该算法并在互联网上查找代码以获得实现它的想法。我在互联网上找到了以下代码并给出了这个奇怪的错误: Exception in thread
我是一名优秀的程序员,十分优秀!