首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ElGamal签名未验证

ElGamal签名未验证
EN

Stack Overflow用户
提问于 2018-07-19 10:17:09
回答 1查看 202关注 0票数 0

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

到目前为止,这就是我所尝试的,但没有运气。

代码语言:javascript
复制
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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-19 10:43:26

P一定是素数。请参阅这里 (这是您使用代码的电子书):

创建一个随机素数,p。这个数是ElGamal“模”。表示p所需的位数是公钥的大小,因此如果p使用1024位来表示,那么按照协议创建的密钥就是1024位密钥。我们将选择607作为示例值。

如果查看文本,就会看到生成El的代码( CreateKeyPair()方法)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51420059

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档