/* * @(#)Key.java 1.28 97/01/16 * * Copyright (c) 1995, 1996, 1997 Sun Microsystems, Inc. All Rights Reserved. * * This software is the confidential and proprietary information of Sun * Microsystems, Inc. ("Confidential Information"). You shall not * disclose such Confidential Information and shall use it only in * accordance with the terms of the license agreement you entered into * with Sun. * * SUN MAKES NO REPRESENTATIONS OR WARRANTIES ABOUT THE SUITABILITY OF THE * SOFTWARE, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE * IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR * PURPOSE, OR NON-INFRINGEMENT. SUN SHALL NOT BE LIABLE FOR ANY DAMAGES * SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR DISTRIBUTING * THIS SOFTWARE OR ITS DERIVATIVES. * * CopyrightVersion 1.1_beta * */ package java.security; /** * The Key interface is the top-level interface for all keys. It * defines the functionality shared by all key objects. All keys * have three characteristics: * * * * Keys are generally obtained through key generators, certificates, * or various Identity classes used to manage keys. There are no * provisions in this release for the parsing of encoded keys and * certificates. * * @see PublicKey * @see PrivateKey * @see KeyPair * @see KeyPairGenerator * @see Identity * @see IdentityScope * @see Signer * * @version 1.28, 97/01/29 * @author Benjamin Renaud */ public interface Key extends java.io.Serializable { /** * Returns the standard algorithm name this key is for. For * example, "DSA" would indicate that this key is a DSA key. * Note that this method may return null, when the * algorithm this key is for is unknown. * *

See Appendix A in the * Java Cryptography Architecture API Specification & Reference * for information about standard algorithm names. * * @return the name of the algorithm this key is for, or null * if the algorithm this key is for is unknown. */ public String getAlgorithm(); /** * Returns the format used to encode the key or null if the key does not * support encoding. * * @return the format used to encode the key. */ public String getFormat(); /** * Returns the encoded key. * * @return the encoded key, or null if the key does not support * encoding. * */ public byte[] getEncoded(); }