public abstract class KeyFactorySpi extends Object
KeyFactory
类。
该类中的所有抽象方法必须由希望提供特定算法的关键工厂的实现的每个加密服务提供商来实现。
主要工厂用于将密钥 (类型为Key
不透明加密密钥)转换为密钥规范 (基础密钥材料的透明表示),反之亦然。
主要工厂是双向的。 也就是说,它们允许您从给定的密钥规范(密钥材料)构建一个不透明的密钥对象,或以合适的格式检索密钥对象的基础密钥。
同一个密钥可能存在多个兼容的密钥规范。 例如,可以使用DSAPublicKeySpec
或X509EncodedKeySpec
指定DSA公钥。 一个关键的工厂可用于在兼容的密钥规范之间进行转换。
供应商应记录其关键工厂支持的所有关键规格。
KeyFactory
, Key
, PublicKey
, PrivateKey
, KeySpec
, DSAPublicKeySpec
, X509EncodedKeySpec
Constructor and Description |
---|
KeyFactorySpi() |
Modifier and Type | Method and Description |
---|---|
protected abstract PrivateKey |
engineGeneratePrivate(KeySpec keySpec)
从提供的密钥规范(密钥材料)生成私钥对象。
|
protected abstract PublicKey |
engineGeneratePublic(KeySpec keySpec)
从提供的密钥规范(密钥材料)生成公钥对象。
|
protected abstract <T extends KeySpec> |
engineGetKeySpec(Key key, 类<T> keySpec)
返回给定键对象的规范(关键材料)。
|
protected abstract Key |
engineTranslateKey(Key key)
将其提供者可能未知或潜在不受信任的关键对象转换为该关键工厂的相应关键对象。
|
protected abstract PublicKey engineGeneratePublic(KeySpec keySpec) throws InvalidKeySpecException
keySpec
- 公钥的规范(密钥材料)。
InvalidKeySpecException
- 如果给定的密钥规范不适合该密钥工厂生成公钥。
protected abstract PrivateKey engineGeneratePrivate(KeySpec keySpec) throws InvalidKeySpecException
keySpec
- 私钥的规范(密钥材料)。
InvalidKeySpecException
- 如果给定的密钥规范不适合该密钥工厂生成私钥。
protected abstract <T extends KeySpec> T engineGetKeySpec(Key key, 类<T> keySpec) throws InvalidKeySpecException
keySpec
标识了应在其中返回密钥材料的规范类。
例如,它可以是DSAPublicKeySpec.class
,以表明在DSAPublicKeySpec
类的实例中应该返回密钥材料。
T
- 要返回的密钥规范的类型
key
- 关键。
keySpec
- 应该返回密钥材料的规范类。
InvalidKeySpecException
- 如果所请求的密钥规范不适用于给定的密钥,或给定的密钥不能被处理(例如,给定的密钥具有无法识别的格式)。
protected abstract Key engineTranslateKey(Key key) throws InvalidKeyException
key
- 提供者未知或不信任的关键。
InvalidKeyException
- if the given key cannot be processed by this key factory.