dhkeypairgenerator.java

来自「一个非常好的ssh客户端实现」· Java 代码 · 共 73 行

JAVA
73
字号
/****************************************************************************** * * Copyright (c) 1999-2003 AppGate Network Security AB. All Rights Reserved. *  * This file contains Original Code and/or Modifications of Original Code as * defined in and that are subject to the MindTerm Public Source License, * Version 2.0, (the 'License'). You may not use this file except in compliance * with the License. *  * You should have received a copy of the MindTerm Public Source License * along with this software; see the file LICENSE.  If not, write to * AppGate Network Security AB, Otterhallegatan 2, SE-41118 Goteborg, SWEDEN * *****************************************************************************/package com.mindbright.security.publickey;import java.math.BigInteger;import com.mindbright.jca.security.KeyPair;import com.mindbright.jca.security.KeyPairGenerator;import com.mindbright.jca.security.SecureRandom;import com.mindbright.jca.security.InvalidAlgorithmParameterException;import com.mindbright.jca.security.spec.AlgorithmParameterSpec;import com.mindbright.jce.crypto.spec.DHParameterSpec;public class DHKeyPairGenerator extends KeyPairGenerator {    protected DHParameterSpec params;    protected SecureRandom    random;    public DHKeyPairGenerator() {	super("DH");    }    public void initialize(int keysize, SecureRandom random) {	throw new Error("Not implemented: " +			"'DHKeyPairGenerator.initialize(int, SecureRandom)'");    }    public void initialize(AlgorithmParameterSpec params, SecureRandom random)	throws InvalidAlgorithmParameterException    {	if(!(params instanceof DHParameterSpec)) {	    throw new InvalidAlgorithmParameterException("Invalid params: " +							 params);	}	this.params = (DHParameterSpec)params;	this.random = random;    }    public KeyPair generateKeyPair() {	BigInteger g = params.getG();	BigInteger p = params.getP();	int        l = params.getL();	if(l == 0) {	    l = p.bitLength();	}	if(random == null) {	    random = new SecureRandom();	}	BigInteger x = DiffieHellman.generateX(p, l, random);	BigInteger y = DiffieHellman.generateY(x, g, p);	return new KeyPair(new DHPublicKey(y, p, g), new DHPrivateKey(x, p, g));    }}

⌨️ 快捷键说明

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