dsakeypairgenerator.java

来自「《移动Agent技术》一书的所有章节源代码。」· Java 代码 · 共 59 行

JAVA
59
字号
package org.bouncycastle.crypto.generators;import java.math.BigInteger;import java.security.SecureRandom;import org.bouncycastle.crypto.KeyGenerationParameters;import org.bouncycastle.crypto.AsymmetricCipherKeyPair;import org.bouncycastle.crypto.AsymmetricCipherKeyPairGenerator;import org.bouncycastle.crypto.params.DSAParameters;import org.bouncycastle.crypto.params.DSAPublicKeyParameters;import org.bouncycastle.crypto.params.DSAPrivateKeyParameters;import org.bouncycastle.crypto.params.DSAKeyGenerationParameters;/** * a DSA key pair generator. * * This generates DSA keys in line with the method described  * in FIPS 186-2. */public class DSAKeyPairGenerator    implements AsymmetricCipherKeyPairGenerator{    private static BigInteger ZERO = BigInteger.valueOf(0);    private DSAKeyGenerationParameters param;    public void init(        KeyGenerationParameters param)    {        this.param = (DSAKeyGenerationParameters)param;    }    public AsymmetricCipherKeyPair generateKeyPair()    {        BigInteger      p, q, g, x, y;        DSAParameters   dsaParams = param.getParameters();        SecureRandom    random = param.getRandom();        q = dsaParams.getQ();        p = dsaParams.getP();        g = dsaParams.getG();        do        {            x = new BigInteger(160, random);        }        while (x.equals(ZERO) || x.compareTo(q) >= 0);        //        // calculate the public key.        //        y = g.modPow(x, p);        return new AsymmetricCipherKeyPair(                new DSAPublicKeyParameters(y, dsaParams),                new DSAPrivateKeyParameters(x, dsaParams));    }}

⌨️ 快捷键说明

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