Class Provider.Service
- Enclosing class:
- Provider
public static class Provider.Service extends Object
Each service has a provider that offers the service, a type, an algorithm name, and the name of the class that implements the service. Optionally, it also includes a list of alternate algorithm names for this service (aliases) and attributes, which are a map of (name, value) String pairs.
This class defines the methods supportsParameter()
and newInstance()
which are used by the Java security framework when it searches for suitable services and instantiates them. The valid arguments to those methods depend on the type of service. For the service types defined within Java SE, see the Java Cryptography Architecture (JCA) Reference Guide for the valid values. Note that components outside of Java SE can define additional types of services and their behavior.
Instances of this class are immutable.
- Since:
- 1.5
Constructor Summary
Constructor | Description |
---|---|
Service |
Construct a new service. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
final String |
getAlgorithm() |
Return the name of the algorithm of this service. |
final String |
getAttribute |
Return the value of the specified attribute or null if this attribute is not set for this Service. |
final String |
getClassName() |
Return the name of the class implementing this service. |
final Provider |
getProvider() |
Return the Provider of this service. |
final String |
getType() |
Get the type of this service. |
Object |
newInstance |
Return a new instance of the implementation described by this service. |
boolean |
supportsParameter |
Test whether this Service can use the specified parameter. |
String |
toString() |
Return a String representation of this service. |
Constructor Details
Service
public Service(Provider provider, String type, String algorithm, String className, List<String> aliases, Map<String,String> attributes)
- Parameters:
-
provider
- the provider that offers this service -
type
- the type of this service -
algorithm
- the algorithm name -
className
- the name of the class implementing this service -
aliases
- List of aliases or null if algorithm has no aliases -
attributes
- Map of attributes or null if this implementation has no attributes - Throws:
-
NullPointerException
- if provider, type, algorithm, or className is null
Method Details
getType
public final String getType()
MessageDigest
.- Returns:
- the type of this service
getAlgorithm
public final String getAlgorithm()
SHA-1
.- Returns:
- the algorithm of this service
getProvider
public final Provider getProvider()
- Returns:
- the Provider of this service
getClassName
public final String getClassName()
- Returns:
- the name of the class implementing this service
getAttribute
public final String getAttribute(String name)
- Parameters:
-
name
- the name of the requested attribute - Returns:
- the value of the specified attribute or null if the attribute is not present
- Throws:
-
NullPointerException
- if name is null
newInstance
public Object newInstance(Object constructorParameter) throws NoSuchAlgorithmException
The default implementation uses reflection to invoke the standard constructor for this type of service. Security providers can override this method to implement instantiation in a different way. For details and the values of constructorParameter that are valid for the various types of services see the Java Cryptography Architecture (JCA) Reference Guide.
- Parameters:
-
constructorParameter
- the value to pass to the constructor, or null if this type of service does not use a constructorParameter. - Returns:
- a new implementation of this service
- Throws:
-
InvalidParameterException
- if the value of constructorParameter is invalid for this type of service. -
NoSuchAlgorithmException
- if instantiation failed for any other reason.
supportsParameter
public boolean supportsParameter(Object parameter)
The security provider framework uses this method with some types of services to quickly exclude non-matching implementations for consideration. Applications will typically not need to call it.
For details and the values of parameter that are valid for the various types of services see the top of this class and the Java Cryptography Architecture (JCA) Reference Guide. Security providers can override it to implement their own test.
- Parameters:
-
parameter
- the parameter to test - Returns:
- false if this service cannot use the specified parameter; true if it can possibly use the parameter
- Throws:
-
InvalidParameterException
- if the value of parameter is invalid for this type of service or if this method cannot be used with this type of service
toString
public String toString()
© 1993, 2021, 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/17/docs/api/java.base/java/security/Provider.Service.html