AlgorithmParameterGeneratorpublic class AlgorithmParameterGenerator extends Object The AlgorithmParameterGenerator class is used to generate a
set of
parameters to be used with a certain algorithm. Parameter generators
are constructed using the getInstance factory methods
(static methods that return instances of a given class).
The object that will generate the parameters can be initialized
in two different ways: in an algorithm-independent manner, or in an
algorithm-specific manner:
- The algorithm-independent approach uses the fact that all parameter
generators share the concept of a "size" and a
source of randomness. The measure of size is universally shared
by all algorithm parameters, though it is interpreted differently
for different algorithms. For example, in the case of parameters for
the DSA algorithm, "size" corresponds to the size
of the prime modulus (in bits).
When using this approach, algorithm-specific parameter generation
values - if any - default to some standard values, unless they can be
derived from the specified size.
- The other approach initializes a parameter generator object
using algorithm-specific semantics, which are represented by a set of
algorithm-specific parameter generation values. To generate
Diffie-Hellman system parameters, for example, the parameter generation
values usually
consist of the size of the prime modulus and the size of the
random exponent, both specified in number of bits.
In case the client does not explicitly initialize the
AlgorithmParameterGenerator
(via a call to an init method), each provider must supply (and
document) a default initialization. For example, the Sun provider uses a
default modulus prime size of 1024 bits for the generation of DSA
parameters. |
Fields Summary |
---|
private Provider | provider | private AlgorithmParameterGeneratorSpi | paramGenSpi | private String | algorithm |
Constructors Summary |
---|
protected AlgorithmParameterGenerator(AlgorithmParameterGeneratorSpi paramGenSpi, Provider provider, String algorithm)Creates an AlgorithmParameterGenerator object.
this.paramGenSpi = paramGenSpi;
this.provider = provider;
this.algorithm = algorithm;
|
Methods Summary |
---|
public final java.security.AlgorithmParameters | generateParameters()Generates the parameters.
return paramGenSpi.engineGenerateParameters();
| public final java.lang.String | getAlgorithm()Returns the standard name of the algorithm this parameter
generator is associated with.
return this.algorithm;
| public static java.security.AlgorithmParameterGenerator | getInstance(java.lang.String algorithm)Generates an AlgorithmParameterGenerator object that implements the
specified digest algorithm. If the default provider package
provides an implementation of the requested digest algorithm,
an instance of AlgorithmParameterGenerator containing that
implementation
is returned. If the algorithm is not available in the default
package, other packages are searched.
try {
Object[] objs = Security.getImpl(algorithm,
"AlgorithmParameterGenerator",
(String)null);
return new AlgorithmParameterGenerator
((AlgorithmParameterGeneratorSpi)objs[0],
(Provider)objs[1],
algorithm);
} catch(NoSuchProviderException e) {
throw new NoSuchAlgorithmException(algorithm + " not found");
}
| public static java.security.AlgorithmParameterGenerator | getInstance(java.lang.String algorithm, java.lang.String provider)Generates an AlgorithmParameterGenerator object for the requested
algorithm, as supplied from the specified provider,
if such a parameter generator is available from the provider.
if (provider == null || provider.length() == 0)
throw new IllegalArgumentException("missing provider");
Object[] objs = Security.getImpl(algorithm,
"AlgorithmParameterGenerator",
provider);
return new AlgorithmParameterGenerator
((AlgorithmParameterGeneratorSpi)objs[0], (Provider)objs[1],
algorithm);
| public static java.security.AlgorithmParameterGenerator | getInstance(java.lang.String algorithm, java.security.Provider provider)Generates an AlgorithmParameterGenerator object for the requested
algorithm, as supplied from the specified provider,
if such a parameter generator is available from the provider.
Note: the provider doesn't have to be registered.
if (provider == null)
throw new IllegalArgumentException("missing provider");
Object[] objs = Security.getImpl(algorithm,
"AlgorithmParameterGenerator",
provider);
return new AlgorithmParameterGenerator
((AlgorithmParameterGeneratorSpi)objs[0], (Provider)objs[1],
algorithm);
| public final java.security.Provider | getProvider()Returns the provider of this algorithm parameter generator object.
return this.provider;
| public final void | init(java.security.spec.AlgorithmParameterSpec genParamSpec, java.security.SecureRandom random)Initializes this parameter generator with a set of algorithm-specific
parameter generation values.
paramGenSpi.engineInit(genParamSpec, random);
| public final void | init(int size)Initializes this parameter generator for a certain size.
To create the parameters, the SecureRandom
implementation of the highest-priority installed provider is used as
the source of randomness.
(If none of the installed providers supply an implementation of
SecureRandom , a system-provided source of randomness is
used.)
paramGenSpi.engineInit(size, new SecureRandom());
| public final void | init(int size, java.security.SecureRandom random)Initializes this parameter generator for a certain size and source
of randomness.
paramGenSpi.engineInit(size, random);
| public final void | init(java.security.spec.AlgorithmParameterSpec genParamSpec)Initializes this parameter generator with a set of algorithm-specific
parameter generation values.
To generate the parameters, the SecureRandom
implementation of the highest-priority installed provider is used as
the source of randomness.
(If none of the installed providers supply an implementation of
SecureRandom , a system-provided source of randomness is
used.)
paramGenSpi.engineInit(genParamSpec, new SecureRandom());
|
|