ElGamal签名未验证

时间:2018-07-19 10:17:10

标签: c# encryption elgamal

我想从此链接https://csharp.hotexamples.com/examples/Portable.Licensing.Security.Cryptography.ElGamal/ElGamalKeyStruct/-/php-elgamalkeystruct-class-examples.html实施ElGamal加密

这是我到目前为止尝试过的,没有运气

string lic = "abcdefghijklmnopqrstuvwxyz";
byte[] licenseKey = Encoding.UTF8.GetBytes(lic);

ElGamalKeyStruct key = new ElGamalKeyStruct();
key.P = new BigInteger(123567890);
key.G = new BigInteger(1234567890);
key.Y = new BigInteger(1234567890);
key.X = new BigInteger(0); //zero

byte[] signature = CreateSignature(licenseKey, key);
bool verified = VerifySignature(licenseKey, signature, key);

VerifySignature始终返回false

1 个答案:

答案 0 :(得分:1)

P必须是素数。请参阅here(这是使用您的代码的电子书):

  

创建一个随机质数p。该数字是ElGamal的“模量”。表示p所需的位数是公共密钥的大小,因此,如果使用1024位表示p,则遵循该协议创建的密钥就是1024位密钥。我们将选择607作为示例值。

如果您在文本中查找,则有代码可以生成El Gamal键(CreateKeyPair()方法)