public class AlgorithmParameters extends Object
An AlgorithmParameters object for managing the parameters for a particular algorithm can be obtained by calling one of the getInstance factory methods (static methods that return instances of a given class). 
Once an AlgorithmParameters object is obtained, it must be initialized via a call to init, using an appropriate parameter specification or parameter encoding. 
A transparent parameter specification is obtained from an AlgorithmParameters object via a call to getParameterSpec, and a byte encoding of the parameters is obtained via a call to getEncoded. 
 Every implementation of the Java platform is required to support the following standard AlgorithmParameters algorithms: 
AESDESedeDiffieHellmanDSA| Modifier | Constructor | Description | 
|---|---|---|
| protected  | Creates an  AlgorithmParametersobject. | 
| Modifier and Type | Method | Description | 
|---|---|---|
| final String | getAlgorithm() | Returns the name of the algorithm associated with this parameter object. | 
| final byte[] | getEncoded() | Returns the parameters in their primary encoding format. | 
| final byte[] | getEncoded | Returns the parameters encoded in the specified scheme. | 
| static AlgorithmParameters | getInstance | Returns a parameter object for the specified algorithm. | 
| static AlgorithmParameters | getInstance | Returns a parameter object for the specified algorithm. | 
| static AlgorithmParameters | getInstance | Returns a parameter object for the specified algorithm. | 
| final <T extends AlgorithmParameterSpec> | getParameterSpec | Returns a (transparent) specification of this parameter object. | 
| final Provider | getProvider() | Returns the provider of this parameter object. | 
| final void | init | Imports the specified parameters and decodes them according to the primary decoding format for parameters. | 
| final void | init | Imports the parameters from  paramsand decodes them according to the specified decoding scheme. | 
| final void | init | Initializes this parameter object using the parameters specified in  paramSpec. | 
| final String | toString() | Returns a formatted string describing the parameters. | 
protected AlgorithmParameters(AlgorithmParametersSpi paramSpi, Provider provider, String algorithm)
AlgorithmParameters object.paramSpi - the delegateprovider - the provideralgorithm - the algorithmpublic final String getAlgorithm()
public static AlgorithmParameters getInstance(String algorithm) throws NoSuchAlgorithmException
 This method traverses the list of registered security providers, starting with the most preferred provider. A new AlgorithmParameters object encapsulating the AlgorithmParametersSpi implementation from the first provider that supports the specified algorithm is returned. 
 Note that the list of registered providers may be retrieved via the Security.getProviders() method. 
 The returned parameter object must be initialized via a call to init, using an appropriate parameter specification or parameter encoding.
jdk.security.provider.preferred Security property to determine the preferred provider order for the specified algorithm. This may be different from the order of providers returned by Security.getProviders().algorithm - the name of the algorithm requested. See the AlgorithmParameters section in the  Java Security Standard Algorithm Names Specification for information about standard algorithm names.NoSuchAlgorithmException - if no Provider supports an AlgorithmParametersSpi implementation for the specified algorithmNullPointerException - if algorithm is null
public static AlgorithmParameters getInstance(String algorithm, String provider) throws NoSuchAlgorithmException, NoSuchProviderException
 A new AlgorithmParameters object encapsulating the AlgorithmParametersSpi implementation from the specified provider is returned. The specified provider must be registered in the security provider list. 
 Note that the list of registered providers may be retrieved via the Security.getProviders() method. 
The returned parameter object must be initialized via a call to init, using an appropriate parameter specification or parameter encoding.
algorithm - the name of the algorithm requested. See the AlgorithmParameters section in the  Java Security Standard Algorithm Names Specification for information about standard algorithm names.provider - the name of the provider.IllegalArgumentException - if the provider name is null or emptyNoSuchAlgorithmException - if an AlgorithmParametersSpi implementation for the specified algorithm is not available from the specified providerNoSuchProviderException - if the specified provider is not registered in the security provider listNullPointerException - if algorithm is null
public static AlgorithmParameters getInstance(String algorithm, Provider provider) throws NoSuchAlgorithmException
 A new AlgorithmParameters object encapsulating the AlgorithmParametersSpi implementation from the specified provider is returned. Note that the specified provider does not have to be registered in the provider list. 
The returned parameter object must be initialized via a call to init, using an appropriate parameter specification or parameter encoding.
algorithm - the name of the algorithm requested. See the AlgorithmParameters section in the  Java Security Standard Algorithm Names Specification for information about standard algorithm names.provider - the name of the provider.IllegalArgumentException - if the provider is null
NoSuchAlgorithmException - if an AlgorithmParameterGeneratorSpi implementation for the specified algorithm is not available from the specified Provider objectNullPointerException - if algorithm is null
public final Provider getProvider()
public final void init(AlgorithmParameterSpec paramSpec) throws InvalidParameterSpecException
paramSpec.paramSpec - the parameter specification.InvalidParameterSpecException - if the given parameter specification is inappropriate for the initialization of this parameter object, or if this parameter object has already been initialized.public final void init(byte[] params) throws IOException
params - the encoded parameters.IOException - on decoding errors, or if this parameter object has already been initialized.public final void init(byte[] params, String format) throws IOException
params and decodes them according to the specified decoding scheme. If format is null, the primary decoding format for parameters is used. The primary decoding format is ASN.1, if an ASN.1 specification for these parameters exists.params - the encoded parameters.format - the name of the decoding scheme.IOException - on decoding errors, or if this parameter object has already been initialized.public final <T extends AlgorithmParameterSpec> T getParameterSpec(Class<T> paramSpec) throws InvalidParameterSpecException
paramSpec identifies the specification class in which the parameters should be returned. It could, for example, be DSAParameterSpec.class, to indicate that the parameters should be returned in an instance of the DSAParameterSpec class.T - the type of the parameter specification to be returnedparamSpec - the specification class in which the parameters should be returned.InvalidParameterSpecException - if the requested parameter specification is inappropriate for this parameter object, or if this parameter object has not been initialized.public final byte[] getEncoded() throws IOException
IOException - on encoding errors, or if this parameter object has not been initialized.public final byte[] getEncoded(String format) throws IOException
format is null, the primary encoding format for parameters is used. The primary encoding format is ASN.1, if an ASN.1 specification for these parameters exists.format - the name of the encoding format.IOException - on encoding errors, or if this parameter object has not been initialized.public final String toString()
    © 1993, 2023, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
    https://docs.oracle.com/en/java/javase/21/docs/api/java.base/java/security/AlgorithmParameters.html