SecureRandomSpi (Java SE 9 & JDK 9 ) (original) (raw)


public abstract class SecureRandomSpi
extends Object
implements Serializable
This class defines the Service Provider Interface (SPI) for the SecureRandom class.
All the abstract methods in this class must be implemented by each service provider who wishes to supply the implementation of a cryptographically strong pseudo-random number generator.
Implementation Requirements:
If the SecureRandomSpi(SecureRandomParameters) constructor is overridden in an implementation, it will always be called whenever a SecureRandom is instantiated. Precisely, if an object is instantiated with one of SecureRandom's getInstance methods_without_ a SecureRandomParameters parameter, the constructor will be called with a null argument and the implementation is responsible for creating its ownSecureRandomParameters parameter for use whenengineGetParameters() is called. If an object is instantiated with one of SecureRandom's getInstance methods with a SecureRandomParameters argument, the constructor will be called with that argument. TheengineGetParameters() method must not return null.
Otherwise, if the SecureRandomSpi(SecureRandomParameters) constructor is not overridden in an implementation, theSecureRandomSpi() constructor must be overridden and it will be called if an object is instantiated with one of SecureRandom'sgetInstance methods without aSecureRandomParameters argument. Calling one ofSecureRandom's getInstance methods with a SecureRandomParameters argument will never return an instance of this implementation. TheengineGetParameters() method must return null.
See SecureRandom for additional details on thread safety. By default, a SecureRandomSpi implementation is considered to be not safe for use by multiple concurrent threads and SecureRandom will synchronize access to each of the applicable engine methods (see SecureRandom for the list of methods). However, if aSecureRandomSpi implementation is thread-safe, the service provider attribute "ThreadSafe" should be set to "true" during its registration, as follows:

put("SecureRandom.AlgName ThreadSafe", "true");
or
putService(new Service(this, "SecureRandom", "AlgName", className,
null, Map.of("ThreadSafe", "true")));
SecureRandom will call the applicable engine methods without any synchronization.
Since:
1.2
See Also:
Serialized Form

Report a bug or suggest an enhancement
For further API reference and developer documentation see the Java SE Documentation, which contains more detailed, developer-targeted descriptions with conceptual overviews, definitions of terms, workarounds, and working code examples.
Java is a trademark or registered trademark of Oracle and/or its affiliates in the US and other countries.
Copyright © 1993, 2017, Oracle and/or its affiliates, 500 Oracle Parkway, Redwood Shores, CA 94065 USA.
All rights reserved. Use is subject to license terms and the documentation redistribution policy.