我想从此链接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
。
答案 0 :(得分:1)
P必须是素数。请参阅here(这是使用您的代码的电子书):
创建一个随机质数p。该数字是ElGamal的“模量”。表示p所需的位数是公共密钥的大小,因此,如果使用1024位表示p,则遵循该协议创建的密钥就是1024位密钥。我们将选择607作为示例值。
如果您在文本中查找,则有代码可以生成El Gamal键(CreateKeyPair()
方法)