該接口實(shí)現(xiàn)了序列化,聲明為 public interface Key extends Serializable
Key 是所有密鑰的頂層接口。它定義了供所有密鑰對(duì)象共享的功能。所有的密鑰都具有三個(gè)特征:
①、算法
這是該密鑰的密鑰算法。密鑰算法通常是加密或不對(duì)稱操作算法(如 DSA 或 RSA),它們將和那些算法及相關(guān)的算法(例如 MD5 和 RSA,SHA-1 和 RSA、Raw DSA 等等)一起使用。用 getAlgorithm 方法獲取密鑰算法的名稱。
②、編碼形式
這是密鑰的外部編碼形式,在 Java 虛擬機(jī)之外需要密鑰的標(biāo)準(zhǔn)表示形式時(shí)以及將密鑰傳輸?shù)狡渌承┎糠謺r(shí)使用。密鑰根據(jù)標(biāo)準(zhǔn)格式(如 X.509 SubjectPublicKeyInfo 或 PKCS#8)編碼,使用 getEncoded 方法返回。注:ASN.1 類型 SubjectPublicKeyInfo 的語法定義如下:
SubjectPublicKeyInfo ::= SEQUENCE { algorithm AlgorithmIdentifier, subjectPublicKey BIT STRING }
AlgorithmIdentifier ::= SEQUENCE { algorithm OBJECT IDENTIFIER, parameters ANY DEFINED BY algorithm OPTIONAL }
③、格式
這是已編碼密鑰的格式的名稱。它由 getFormat 方法返回。
密鑰通常通過密鑰生成器、證書或用來管理密鑰的各種 Identity 類來獲取。密鑰也可以通過使用密鑰工廠(請(qǐng)參見 KeyFactory)從密鑰規(guī)范(基礎(chǔ)密鑰材料的透明表示形式)獲取。
密鑰應(yīng)該使用 KeyRep 作為其序列化的表示形式。注意,序列化的 Key 可能包含不應(yīng)該在不可信任的環(huán)境中顯示的敏感信息。有關(guān)更多信息,請(qǐng)參見序列化規(guī)范的安全附錄。
1、字段:
static final long serialVersionUID 設(shè)置為指示與以前的類版本序列化兼容的類指紋。 2、方法詳細(xì):
①String getAlgorithm() 返回此密鑰的標(biāo)準(zhǔn)算法名稱。例如,"DSA" 指示此密鑰是一個(gè) DSA 密鑰。
②String getFormat() 返回此密鑰的基本編碼格式,如果此密鑰不支持編碼,則返回 null。如果存在此密鑰的 ASN.1 規(guī)范,則根據(jù)合適的 ASN.1 數(shù)據(jù)格式命名基本編碼格式。例如,公鑰的 ASN.1 數(shù)據(jù)格式名稱是 SubjectPublicKeyInfo(由 X.509 標(biāo)準(zhǔn)定義);在這種情況下,返回的格式為 "X.509"。類似地,私鑰的 ASN.1 數(shù)據(jù)格式名稱是 PrivateKeyInfo(由 PKCS #8 標(biāo)準(zhǔn)定義);在這種情況下,返回的格式為 "PKCS#8"。
③byte[] getEncoded() 返回基本編碼格式的密鑰,如果此密鑰不支持編碼,則返回 null。