首页 > 代码库 > java中的秘钥工厂KeyFactory
java中的秘钥工厂KeyFactory
一、概述
该类位于java.security包下,声明:public classKeyFactory extends Object
密钥工厂用于将密钥(Key
类型的不透明加密密钥)转换成密钥规范(底层密钥材料的透明表示),反之亦然。
密钥工厂是双向的。也就是说,它们允许根据给定的密钥规范(密钥材料)构建不透明的密钥对象,也允许获取以恰当格式表示的密钥对象的底层密钥材料。
对于同一个密钥可以存在多个兼容的密钥规范。例如,可以使用 DSAPublicKeySpec
或 X509EncodedKeySpec
指定 DSA 公钥。密钥工厂可用于兼容密钥规范之间的转换。
以下是一个如何使用密钥工厂根据其编码实例化 DSA 公钥的示例。假定 Alice 收到了 Bob 的数字签名。Bob 也向她发送其公钥(以编码的格式)来验证他的签名。然后 Alice 执行以下操作:
X509EncodedKeySpec bobPubKeySpec = new X509EncodedKeySpec(bobEncodedPubKey); KeyFactory keyFactory = KeyFactory.getInstance("DSA"); PublicKey bobPubKey = keyFactory.generatePublic(bobPubKeySpec); Signature sig = Signature.getInstance("DSA"); sig.initVerify(bobPubKey); sig.update(data); sig.verify(signature);
二、构造方法
protected KeyFactory(KeyFactorySpi keyFacSpi,Provider provider, String algorithm) 创建一个 KeyFactory 对象。
keyFacSpi
- 代理 provider
- 提供者 algorithm
- 与此 KeyFactory 关联的算法名称此方法从首选 Provider 开始遍历已注册安全提供者列表。返回一个封装 KeyFactorySpi 实现的新 KeyFactory 对象,该实现取自第一个支持指定算法的 Provider。
注意,可以通过 Security.getProviders()
方法获取已注册提供者列表。
algorithm
- 请求密钥算法的名称。NoSuchAlgorithmException
- 如果没有 Provider 支持指定算法的 KeyFactorySpi 实现。返回一个封装 KeyFactorySpi 实现的新 KeyFactory 对象,该实现取自指定提供者。指定提供者必须在安全提供者列表中注册。
注意,可以通过 Security.getProviders()
方法获取已注册提供者列表。
algorithm
- 请求密钥算法的名称。有关标准算法名称的信息,请参阅 Java Cryptography Architecture API Specification & Reference 中的附录 A。provider
- 提供者的名称。 NoSuchAlgorithmException
- 如果不能从指定提供者获得指定算法的 KeyFactorySpi 实现。 NoSuchProviderException
- 如果指定提供者未在安全提供者列表中注册。 IllegalArgumentException
- 如果提供者的名称为 null 或空。返回一个封装 KeyFactorySpi 实现的新 KeyFactory 对象,该实现取自指定 Provider 对象。注意,指定 Provider 对象无需在提供者列表中注册。
- 参数:
algorithm
- 请求密钥算法的名称。有关标准算法名称的信息,请参阅 Java Cryptography Architecture API Specification & Reference 中的附录 A。provider
- 提供者。- 返回:
- 新的 KeyFactory 对象。
- 抛出:
NoSuchAlgorithmException
- 如果不能从指定 Provider 对象获得指定算法的 KeyFactorySpi 实现。IllegalArgumentException
- 如果指定提供者为 null。
keySpec
- 公钥的规范(密钥材料)。 InvalidKeySpecException
- 如果给定的密钥规范不适合此密钥工厂生成公钥。keySpec
- 私钥的规范(密钥材料)。 InvalidKeySpecException
- 如果给定的密钥规范不适合此密钥工厂生成私钥。keySpec
标识应接受返回密钥材料的规范类。例如,它可能是 DSAPublicKeySpec.class
,指示密钥材料应该返回到 DSAPublicKeySpec
类的一个实例中。 key
- 密钥。keySpec
- 应接受返回密钥材料的规范类。 InvalidKeySpecException
- 如果请求的密钥规范不适合给定密钥,或无法处理给定密钥(例如,给定密钥具有不能识别的算法或格式)。- 参数:
key
- 提供者未知或不受信任的密钥对象。- 返回:
- 已转换的密钥。
- 抛出:
InvalidKeyException
- 如果此密钥工厂无法处理给定密钥。
java中的秘钥工厂KeyFactory