gpt4 book ai didi

java - Diffie-Hellman 私钥

转载 作者:搜寻专家 更新时间:2023-11-01 01:35:39 24 4
gpt4 key购买 nike

我有下面这行代码来生成私钥:

int Xa = randomNo.nextInt(10000);
int Ya = (int) Math.pow(G, Xa) % P;

GP 是静态数字。而 Xa 是随机生成的。每次我运行该程序时,它都会为我提供相同的 Ya 结果。这对 Diffie-Hellman 来说是否正确?我认为每次运行算法时都必须更改私钥。

最佳答案

问题是 Java 中的 Random 类有一个带有一个 long 参数(称为 seed)的构造函数,它允许您启动特定方式的伪随机数序列。

如果你总是使用相同的种子,你将始终获得相同的序列。

要解决这个问题,试试这个:

Random randomNo = new Random(System.nanoTime());
int Xa = randomNo.nextInt(10000);

这样,种子总是不同的,每次你调用上面这行时,顺序都会改变。

关于java - Diffie-Hellman 私钥,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15483736/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com