⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 jceelgamalprivatekey.java

📁 kmlnjlkj nlkjlkjkljl okopokipoipo oipipipo i
💻 JAVA
字号:
package org.bouncycastle.jce.provider;import org.bouncycastle.asn1.ASN1Sequence;import org.bouncycastle.asn1.DEREncodable;import org.bouncycastle.asn1.DERInteger;import org.bouncycastle.asn1.DERObjectIdentifier;import org.bouncycastle.asn1.oiw.ElGamalParameter;import org.bouncycastle.asn1.oiw.OIWObjectIdentifiers;import org.bouncycastle.asn1.pkcs.PrivateKeyInfo;import org.bouncycastle.asn1.x509.AlgorithmIdentifier;import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters;import org.bouncycastle.jce.interfaces.ElGamalPrivateKey;import org.bouncycastle.jce.interfaces.PKCS12BagAttributeCarrier;import org.bouncycastle.jce.spec.ElGamalParameterSpec;import org.bouncycastle.jce.spec.ElGamalPrivateKeySpec;import javax.crypto.interfaces.DHPrivateKey;import javax.crypto.spec.DHParameterSpec;import javax.crypto.spec.DHPrivateKeySpec;import java.io.IOException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;import java.math.BigInteger;import java.util.Enumeration;public class JCEElGamalPrivateKey    implements ElGamalPrivateKey, DHPrivateKey, PKCS12BagAttributeCarrier{    static final long serialVersionUID = 4819350091141529678L;            BigInteger      x;    ElGamalParameterSpec   elSpec;    private PKCS12BagAttributeCarrierImpl   attrCarrier = new PKCS12BagAttributeCarrierImpl();    protected JCEElGamalPrivateKey()    {    }    JCEElGamalPrivateKey(        ElGamalPrivateKey    key)    {        this.x = key.getX();        this.elSpec = key.getParameters();    }    JCEElGamalPrivateKey(        DHPrivateKey    key)    {        this.x = key.getX();        this.elSpec = new ElGamalParameterSpec(key.getParams().getP(), key.getParams().getG());    }        JCEElGamalPrivateKey(        ElGamalPrivateKeySpec    spec)    {        this.x = spec.getX();        this.elSpec = new ElGamalParameterSpec(spec.getParams().getP(), spec.getParams().getG());    }    JCEElGamalPrivateKey(        DHPrivateKeySpec    spec)    {        this.x = spec.getX();        this.elSpec = new ElGamalParameterSpec(spec.getP(), spec.getG());    }        JCEElGamalPrivateKey(        PrivateKeyInfo  info)    {        ElGamalParameter     params = new ElGamalParameter((ASN1Sequence)info.getAlgorithmId().getParameters());        DERInteger      derX = (DERInteger)info.getPrivateKey();        this.x = derX.getValue();        this.elSpec = new ElGamalParameterSpec(params.getP(), params.getG());    }    JCEElGamalPrivateKey(        ElGamalPrivateKeyParameters  params)    {        this.x = params.getX();        this.elSpec = new ElGamalParameterSpec(params.getParameters().getP(), params.getParameters().getG());    }    public String getAlgorithm()    {        return "ElGamal";    }    /**     * return the encoding format we produce in getEncoded().     *     * @return the string "PKCS#8"     */    public String getFormat()    {        return "PKCS#8";    }    /**     * Return a PKCS8 representation of the key. The sequence returned     * represents a full PrivateKeyInfo object.     *     * @return a PKCS8 representation of the key.     */    public byte[] getEncoded()    {        PrivateKeyInfo          info = new PrivateKeyInfo(new AlgorithmIdentifier(OIWObjectIdentifiers.elGamalAlgorithm, new ElGamalParameter(elSpec.getP(), elSpec.getG()).getDERObject()), new DERInteger(getX()));        return info.getDEREncoded();    }    public ElGamalParameterSpec getParameters()    {        return elSpec;    }    public DHParameterSpec getParams()    {        return new DHParameterSpec(elSpec.getP(), elSpec.getG());    }        public BigInteger getX()    {        return x;    }    private void readObject(        ObjectInputStream   in)        throws IOException, ClassNotFoundException    {        x = (BigInteger)in.readObject();        this.elSpec = new ElGamalParameterSpec((BigInteger)in.readObject(), (BigInteger)in.readObject());    }    private void writeObject(        ObjectOutputStream  out)        throws IOException    {        out.writeObject(this.getX());        out.writeObject(elSpec.getP());        out.writeObject(elSpec.getG());    }    public void setBagAttribute(        DERObjectIdentifier oid,        DEREncodable        attribute)    {        attrCarrier.setBagAttribute(oid, attribute);    }    public DEREncodable getBagAttribute(        DERObjectIdentifier oid)    {        return attrCarrier.getBagAttribute(oid);    }    public Enumeration getBagAttributeKeys()    {        return attrCarrier.getBagAttributeKeys();    }}

⌨️ 快捷键说明

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