elgamalkeypairgenerator.java

来自「kmlnjlkj nlkjlkjkljl okopokipoipo oipipi」· Java 代码 · 共 47 行

JAVA
47
字号
package org.bouncycastle.crypto.generators;import java.math.BigInteger;import org.bouncycastle.crypto.AsymmetricCipherKeyPair;import org.bouncycastle.crypto.AsymmetricCipherKeyPairGenerator;import org.bouncycastle.crypto.KeyGenerationParameters;import org.bouncycastle.crypto.params.ElGamalKeyGenerationParameters;import org.bouncycastle.crypto.params.ElGamalParameters;import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters;import org.bouncycastle.crypto.params.ElGamalPublicKeyParameters;/** * a ElGamal key pair generator. * <p> * This generates keys consistent for use with ElGamal as described in * page 164 of "Handbook of Applied Cryptography". */public class ElGamalKeyPairGenerator    implements AsymmetricCipherKeyPairGenerator{    private DHKeyGeneratorHelper helper = DHKeyGeneratorHelper.INSTANCE;        private ElGamalKeyGenerationParameters param;    public void init(        KeyGenerationParameters param)    {        this.param = (ElGamalKeyGenerationParameters)param;    }    public AsymmetricCipherKeyPair generateKeyPair()    {        BigInteger           p, x, y;        ElGamalParameters    elParams = param.getParameters();        p = elParams.getP();         x = helper.calculatePrivate(p, param.getRandom(), elParams.getL());         y = helper.calculatePublic(p, elParams.getG(), x);        return new AsymmetricCipherKeyPair(                new ElGamalPublicKeyParameters(y, elParams),                new ElGamalPrivateKeyParameters(x, elParams));    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?