All Downloads are FREE. Search and download functionalities are using the official Maven repository.

java.security.interfaces.DSAKeyPairGenerator Maven / Gradle / Ivy

There is a newer version: 1.3.1
Show newest version
/*

This is not an official specification document, and usage is restricted.

NOTICE


(c) 2005-2007 Sun Microsystems, Inc. All Rights Reserved.

Neither this file nor any files generated from it describe a complete specification, and they may only be used as described below. For example, no permission is given for you to incorporate this file, in whole or in part, in an implementation of a Java specification.

Sun Microsystems Inc. owns the copyright in this file and it is provided to you for informative, as opposed to normative, use. The file and any files generated from it may be used to generate other informative documentation, such as a unified set of documents of API signatures for a platform that includes technologies expressed as Java APIs. The file may also be used to produce "compilation stubs," which allow applications to be compiled and validated for such platforms.

Any work generated from this file, such as unified javadocs or compiled stub files, must be accompanied by this notice in its entirety.

This work corresponds to the API signatures of JSR 219: Foundation Profile 1.1. In the event of a discrepency between this work and the JSR 219 specification, which is available at http://www.jcp.org/en/jsr/detail?id=219, the latter takes precedence. */ package java.security.interfaces; import java.security.*; /** * An interface to an object capable of generating DSA key pairs. * *

The initialize methods may each be called any number * of times. If no initialize method is called on a * DSAKeyPairGenerator, the default is to generate 1024-bit keys, using * precomputed p, q and g parameters and an instance of SecureRandom as * the random bit source. * *

Users wishing to indicate DSA-specific parameters, and to generate a key * pair suitable for use with the DSA algorithm typically * *

    * *
  1. Get a key pair generator for the DSA algorithm by calling the * KeyPairGenerator getInstance method with "DSA" * as its argument.

    * *

  2. Initialize the generator by casting the result to a DSAKeyPairGenerator * and calling one of the * initialize methods from this DSAKeyPairGenerator interface.

    * *

  3. Generate a key pair by calling the generateKeyPair * method from the KeyPairGenerator class. * *
* *

Note: it is not always necessary to do do algorithm-specific * initialization for a DSA key pair generator. That is, it is not always * necessary to call an initialize method in this interface. * Algorithm-independent initialization using the initialize method * in the KeyPairGenerator * interface is all that is needed when you accept defaults for algorithm-specific * parameters. * * @see java.security.KeyPairGenerator */ public interface DSAKeyPairGenerator { /** * Initializes the key pair generator using p, q and g, the DSA * family parameters. * * @param params the parameters to use to generate the keys. * * @param random the random bit source to use to generate * key bits. * * @exception InvalidParameterException if the parameters passed are * invalid or null. */ public void initialize(DSAParams params, SecureRandom random) throws InvalidParameterException; /** * Initializes the key pair generator for a given modulus length, * without parameters. * *

If genParams is true, this method will generate new * p, q and g parameters. If it is false, the method will use precomputed * parameters for the modulus length requested. If there are no * precomputed parameters for that modulus length, an exception will be * thrown. It is guaranteed that there will always be * default parameters for modulus lengths of 512 and 1024 bits. * * @param modlen the modulus length, in bits. Valid values are any * multiple of 8 between 512 and 1024, inclusive. * * @param random the random bit source to use to generate * key bits. * * @param genParams whether or not to generate new parameters for * the modulus length requested. * * @exception InvalidParameterException if the modulus length is not * between 512 and 1024, or if genParams is false and there are * not precomputed parameters for the modulus length requested. */ public void initialize(int modlen, boolean genParams, SecureRandom random) throws InvalidParameterException; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy