- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
要求是:
质数 p 和 q 应至少为 1024 位
两个素数之差应该大于2^512
(安全起见)
问题:我想知道的是我指定了p
和q
的位长,并且还有 SecureRandom
实例来随机生成它们,但我被告知差异可能不会大于 2^512
。那么我如何指定差异,使其大于 2^512
?然后我想我将不再能够随机生成 p
和 q
?
Here是 BigInteger 类构造函数的文档,它表明如果我想手动指定它,我必须使用 bye 数组 byte[]
,如果我这样做,则无法随机生成它。
任何提示都会很棒。
谢谢。
这是我遇到问题的方法:
public RSA(int bits) {
bitlen = bits;
SecureRandom random = new SecureRandom();
BigInteger p = new BigInteger(bitlen, 100, random);
BigInteger q = new BigInteger(bitlen, 100, random);
n = p.multiply(q);
BigInteger m = (p.subtract(BigInteger.ONE)).multiply(q
.subtract(BigInteger.ONE));
e = new BigInteger(Integer.toString(eValue));
while (m.gcd(e).intValue() > 1) {
e = e.add(new BigInteger("2"));
}
d = e.modInverse(m);
}
完整的源代码如下:
import java.math.BigInteger;
import java.security.SecureRandom;
public class RSA {
public static double runningTime;
private BigInteger n, d, e;
private int bitlen = 1024;
static int eValue = 65537;
/** Create an instance that can encrypt using someone provided public key. */
public RSA(BigInteger newn, BigInteger newe) {
n = newn;
e = newe;
}
/** Create an instance that can both encrypt and decrypt. */
public RSA(int bits) {
bitlen = bits;
SecureRandom random = new SecureRandom();
BigInteger p = new BigInteger(bitlen, 100, random);
BigInteger q = new BigInteger(bitlen, 100, random);
n = p.multiply(q);
BigInteger m = (p.subtract(BigInteger.ONE)).multiply(q
.subtract(BigInteger.ONE));
e = new BigInteger(Integer.toString(eValue));
while (m.gcd(e).intValue() > 1) {
e = e.add(new BigInteger("2"));
}
d = e.modInverse(m);
}
/** Encrypt the given plain-text message. */
public String encrypt(String message) {
return (new BigInteger(message.getBytes())).modPow(e, n).toString();
}
/** Encrypt the given plain-text message. */
public BigInteger encrypt(BigInteger message) {
return message.modPow(e, n);
}
/** Decrypt the given cipher-text message. */
public String decrypt(String message) {
return new String((new BigInteger(message)).modPow(d, n).toByteArray());
}
/** Decrypt the given cipher-text message. */
public BigInteger decrypt(BigInteger message) {
return message.modPow(d, n);
}
/** Generate a new public and private key set. */
public void generateKeys() {
SecureRandom random = new SecureRandom();
BigInteger p = new BigInteger(bitlen, 100, random);
BigInteger q = new BigInteger(bitlen, 100, random);
n = p.multiply(q);
BigInteger m = (p.subtract(BigInteger.ONE)).multiply(q
.subtract(BigInteger.ONE));
e = new BigInteger(Integer.toString(eValue));
while (m.gcd(e).intValue() > 1) {
e = e.add(new BigInteger("2"));
}
d = e.modInverse(m);
}
/** Return the modulus. */
public BigInteger getN() {
return n;
}
/** Return the public key. */
public BigInteger getE() {
return e;
}
/** Test program. */
public static void main(String[] args) {
runningTime = System.nanoTime();
RSA rsa = new RSA(1024);
String text1 = "RSA-Encryption Practice";
System.out.println("Plaintext: " + text1);
BigInteger plaintext = new BigInteger(text1.getBytes());
BigInteger ciphertext = rsa.encrypt(plaintext);
System.out.println("cipher-text: " + ciphertext);
plaintext = rsa.decrypt(ciphertext);
String text2 = new String(plaintext.toByteArray());
System.out.println("Plaintext: " + text2);
System.out.println("RunningTime: "
+ (runningTime = System.nanoTime() - runningTime) / 1000000
+ " ms");
}
}
最佳答案
很难随机生成两个相距小于 2512 的 1024 位素数。概率是<2-509(这是不可能的)。所以一般你不应该有问题。如果这种情况仍然发生,您可以在 checkDiff
在 while 循环中返回 false 时重试。这使它成为一种非常快速收敛的拉斯维加斯算法。
final static BigInteger targetDiff = new BigInteger("2").pow(512);
public boolean checkDiff(BigInteger p, BigInteger q){
BigInteger pDiff = p.subtract(q);
pDiff = pDiff.abs();
BigInteger diff = pDiff.subtract(targetDiff);
return diff.compareTo(BigInteger.ZERO) == 1;
}
关于java - 使用 Java 内置库的简单 RSA 加密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26978189/
我试图在 (C) Python 源代码中找到内置 in 运算符的实现。我在内置函数源代码中搜索过,bltinmodule.c ,但找不到此运算符的实现。我在哪里可以找到这个实现? 我的目标是通过扩展此
我们正在开发一个 shell(学校项目)。我们不理解一种行为。为什么内置函数在重定向时不起作用? 喜欢 cd - | command 不改变目录。 或 export NAME=VALUE | comm
有人问有关如何对列表进行排序的问题。从基本List.Sort()到List.OrderBy()有几种方法。最可笑的是自己动手的SelectionSort。我迅速将其否决,但这使我思考。应用于列表的
我正在尝试使用 C 中内置的 qsort 函数对结构进行排序 typedef struct abc{ long long int fir; long long int sec; }abc; 在
我觉得有一些内置的东西。如果对象为空,我想要默认值(或者特别是 0,我只使用十进制/整数)。是否有编写此函数的内置方法? static int GetDecimalFromObject(object
Java 是否有用于生成和解析文档的内置 XML 库?如果不是,我应该使用哪个第三方? 最佳答案 Sun Java 运行时附带 Xerces 和 Xalan 实现,它们提供解析 XML(通过 DOM
我对 python 的“all”和生成器有以下问题: G = (a for a in [0,1]) all(list(G)) # returns False - as I expected 但是:
我有一些使用 gcc 内部函数的代码。我想包含代码以防缺少内在函数。我该怎么做? #ifdef __builtin_ctzll 不起作用。 最佳答案 使用最新版本的 clang,现在可以使用 __ha
人们常说应该在本地重新声明(某些)Lua 函数,因为这样可以减少开销。但这背后的确切规则/原则是什么?我怎么知道哪些功能应该完成,哪些是多余的?还是应该为每个功能完成,甚至是您自己的功能? 不幸的是,
我想实现以下功能: TestClass values 接受任意数量的 NewClass 对象 只有 NewClass 对象没有完全相同的属性值被添加到TestClass.values 我想出了这个:
我正在尝试编写一个存储过程(使用 SQL Server Management Studio 2008 R2)以从表中检索最大测量值。这似乎是一件容易的事,所以我写了一个简短的存储过程来获取 MAX。但
我刚写了我的第一个Electron应用程序。现在,我正在尝试通过electron-packager构建它。我的package.json看起来像这样: { "name": "pixelcast",
我正在寻找在 WPF 应用程序中使用的“安全”字体系列列表 - 应该安装在所有能够运行 WPF 的客户端机器上的字体系列。 Silverlight 有一个明确定义的列表( listed on MSDN
好吧,(在写了几次之后)发现System.Windows.Controls命名空间中已经有一个BooleanToVisibilityConverter,这真是一个惊喜。 可能还有更多这样隐藏的节省时间
在我的 gradle 构建文件中,我有以下插件 block plugins { `java-library` jacoco checkstyle } 这些都没有指定版本,但一切
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 3 年前。 Improve this ques
10 implementations String#reverse 已根据每个浏览器进行分析。 自 2011 年以来已对这些实现进行了解释。 当 ES6 出现时,有很多代码变得更加优雅和性能。 关于
在 Julia 包 BenchmarkTools 中,有一些像 @btime、@belapse 这样的宏对我来说似乎是多余的,因为 Julia 内置了@time、@elapse 宏。在我看来,这些宏服
我正在尝试编写一个简单的 LLVM 通行证,其目标如下: 查找所有 call指示。 在被调用函数中插入我编写的外部函数。 例如,考虑我有以下示例程序: #include #include int
我理解 'a) -> (rhs:'a -> 'a) -> 'a 在我感兴趣的情况下,我经常发现自己想要类似 (lhs:'a -> 'b) -> (rhs:'c -> 'b) -> 'b 的东西在侧面
我是一名优秀的程序员,十分优秀!