⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 smadapter.java

📁 java pos,你可以直接编译运行,
💻 JAVA
字号:
/* * Copyright (c) 2000 jPOS.org.  All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. * * 3. The end-user documentation included with the redistribution, *    if any, must include the following acknowledgment: *    "This product includes software developed by the jPOS project *    (http://www.jpos.org/)". Alternately, this acknowledgment may *    appear in the software itself, if and wherever such third-party *    acknowledgments normally appear. * * 4. The names "jPOS" and "jPOS.org" must not be used to endorse *    or promote products derived from this software without prior *    written permission. For written permission, please contact *    license@jpos.org. * * 5. Products derived from this software may not be called "jPOS", *    nor may "jPOS" appear in their name, without prior written *    permission of the jPOS project. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE JPOS PROJECT OR ITS CONTRIBUTORS BE LIABLE FOR * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the jPOS Project.  For more * information please see <http://www.jpos.org/>. */package  org.jpos.security;/** * A class that implements the SecurityModuleAdapter interface would act as an * adapter to the real security module device (by communicating with it using * its proprietary protocol). * * But application programmers will be communicating * with the security module using this simple interface. * * @todo support for PIN Verification API's and RSA * @author Hani S. Kirollos * @version $Revision: 1.4 $ $Date: 2003/10/13 10:46:15 $ */public interface SMAdapter {    /**     * DES Key Length <code>LENGTH_DES</code> = 64.     */    public static final short LENGTH_DES = 64;    /**     * Triple DES (2 keys) <code>LENGTH_DES3_2KEY</code> = 128.     */    public static final short LENGTH_DES3_2KEY = 128;    /**     * Triple DES (3 keys) <code>LENGTH_DES3_3KEY</code> = 192.     */    public static final short LENGTH_DES3_3KEY = 192;    /**     * ZMK: Zone Master Key is a DES (or Triple-DES) key-encryption key which is distributed     * manually in order that further keys can be exchanged automatically.     */    public static final String TYPE_ZMK = "ZMK";    /**     * ZPK: Zone PIN Key.     *     * is a DES (or Triple-DES) data-encrypting key which is distributed     * automatically and is used to encrypt PINs for transfer between     * communicating parties (e.g. between acquirers and issuers).     */    public static final String TYPE_ZPK = "ZPK";    /**     * TMK: Terminal Master Key.     *     * is a  DES (or Triple-DES) key-encrypting key which is distributed     * manually, or automatically under a previously installed TMK. It is     * used to distribute data-encrypting keys, whithin a local network,     * to an ATM or POS terminal or similar.     */    public static final String TYPE_TMK = "TMK";    /**     * TPK: Terminal PIN Key.     *     * is a  DES (or Triple-DES) data-encrypting key which is used     * to encrypt PINs for transmission, within a local network,     * between the terminal and the terminal data acquirer.     */    public static final String TYPE_TPK = "TPK";    /**     * TAK: Terminal Authentication Key.     *     * is a  DES (or Triple-DES) data-encrypting key which is used to     * generate and verify a Message Authentication Code (MAC) when data     * is transmitted, within a local network, between the terminal and     * the terminal data acquirer.     */    public static final String TYPE_TAK = "TAK";    /**     * PVK: PIN Verification Key.     * is a  DES (or Triple-DES) data-encrypting key which is used to     * generate and verify PIN verification data and thus verify the     * authenticity of a PIN.     */    public static final String TYPE_PVK = "PVK";    /**     * CVK: Card Verification Key.     *     * is similar for PVK but for card information instead of PIN     */    public static final String TYPE_CVK = "CVK";    /**     * BDK: Base Derivation Key.     * is a  Triple-DES key-encryption key used to derive transaction     * keys in DUKPT (see ANSI X9.24)     */    public static final String TYPE_BDK = "BDK";    /**     * ZAK: Zone Authentication Key.     *     * a  DES (or Triple-DES) data-encrypting key that is distributed     * automatically, and is used to generate and verify a Message     * Authentication Code (MAC) when data is transmitted between     * communicating parties (e.g. between acquirers and issuers)     */    public static final String TYPE_ZAK = "ZAK";    /**     * PIN Block Format adopted by ANSI (ANSI X9.8) and is one of     * two formats supported by the ISO (ISO 95641 - format 0).     */    public static final byte FORMAT01 = (byte)01;    /**     * PIN Block Format 02 supports Douctel ATMs.     */    public static final byte FORMAT02 = (byte)02;    /**         * PIN Block Format 03 is the Diabold Pin Block format.         */    public static final byte FORMAT03 = (byte)03;    /**     * PIN Block Format 04 is the PIN block format adopted     * by the PLUS network.     */    public static final byte FORMAT04 = (byte)04;    /**     * PIN Block Format 05 is the ISO 9564-1 Format 1 PIN Block.     */    public static final byte FORMAT05 = (byte)05;    /**     * Proprietary PIN Block format.     *     * Most Security Modules use a proprietary PIN Block format     * when encrypting the PIN under the LMK of the Security Module     * hence this format (FORMAT00).     *     * <p>     * This is not a standard format, every Security Module would     * interpret FORMAT00 differently.     *     * So, no interchange would accept PIN Blocks from other interchanges     * using this format. It is useful only when working with PIN's inside     * your own interchange.     * </p>     */    public static final byte FORMAT00 = (byte)00;    /**     * Generates a random DES Key.     *     * @param keyType type of the key to be generated (TYPE_ZMK, TYPE_TMK...etc)     * @param keyLength bit length of the key to be generated (LENGTH_DES, LENGTH_DES3_2KEY...)     * @return the random key secured by the security module<BR>     * @throws SMException     */    public SecureDESKey generateKey (short keyLength, String keyType) throws SMException;    /**     * Imports a key from encryption under a KEK (Key-Encrypting Key)     * to protection under the security module.     *     * @param keyLength bit length of the key to be imported (LENGTH_DES, LENGTH_DES3_2KEY...etc)     * @param keyType type of the key to be imported (TYPE_ZMK, TYPE_TMK...etc)     * @param encryptedKey key to be imported encrypted under KEK     * @param kek the key-encrypting key     * @param checkParity if true, the key is not imported unless it has adjusted parity     * @return imported key secured by the security module     * @throws SMException if the parity of the imported key is not adjusted AND checkParity = true     */    public SecureDESKey importKey (short keyLength, String keyType, byte[] encryptedKey,            SecureDESKey kek, boolean checkParity) throws SMException;    /**     * Exports secure key to encryption under a KEK (Key-Encrypting Key).     * @param key the secure key to be exported     * @param kek the key-encrypting key     * @return the exported key (key encrypted under kek)     * @throws SMException     */    public byte[] exportKey (SecureDESKey key, SecureDESKey kek) throws SMException;    /**     * Encrypts a clear pin under LMK.     *     * CAUTION: The use of clear pin presents a significant security risk     * @param pin clear pin as entered by card holder     * @param accountNumber The 12 right-most digits of the account number excluding the check digit. Should also function correctly if the complete account number, including the check digit is passed.     * @return PIN under LMK     * @throws SMException     */    public EncryptedPIN encryptPIN (String pin, String accountNumber) throws SMException;    /**     * Decrypts an Encrypted PIN (under LMK).     * CAUTION: The use of clear pin presents a significant security risk     * @param pinUnderLmk     * @return clear pin as entered by card holder     * @throws SMException     */    public String decryptPIN (EncryptedPIN pinUnderLmk) throws SMException;    /**     * Imports a PIN from encryption under KD (Data Key)     * to encryption under LMK.     *     * @param pinUnderKd1 the encrypted PIN     * @param kd1 Data Key under which the pin is encrypted     * @return pin encrypted under LMK     * @throws SMException     */    public EncryptedPIN importPIN (EncryptedPIN pinUnderKd1, SecureDESKey kd1) throws SMException;    /**     * Translates a PIN from encrytion under KD1 to encryption under KD2.     *     * @param pinUnderKd1 pin encrypted under KD1     * @param kd1 Data Key (also called session key) under which the pin is encrypted     * @param kd2 the destination Data Key 2 under which the pin will be encrypted     * @param destinationPINBlockFormat the PIN Block Format of the exported encrypted PIN     * @return pin encrypted under KD2     * @throws SMException     */    public EncryptedPIN translatePIN (EncryptedPIN pinUnderKd1, SecureDESKey kd1,            SecureDESKey kd2, byte destinationPINBlockFormat) throws SMException;    /**     * Imports a PIN from encryption under a transaction key to encryption     * under LMK.     *     * The transaction key is derived from the Key Serial Number and the Base Derivation Key using DUKPT (Derived Unique Key per Transaction). See ANSI X9.24 for more information.     * @param pinUnderDuk pin encrypted under a transaction key     * @param ksn Key Serial Number (also called Key Name, in ANSI X9.24) needed to derive the transaction key     * @param bdk Base Derivation Key, used to derive the transaction key underwhich the pin is encrypted     * @return pin encrypted under LMK     * @throws SMException     */    public EncryptedPIN importPIN (EncryptedPIN pinUnderDuk, KeySerialNumber ksn,            SecureDESKey bdk) throws SMException;    /**     * Translates a PIN from encryption under a transaction key to     * encryption under a KD (Data Key).     *     * The transaction key is derived from the Key Serial Number and the Base Derivation Key using DUKPT (Derived Unique Key per Transaction). See ANSI X9.24 for more information.     * @param pinUnderDuk pin encrypted under a DUKPT transaction key     * @param ksn Key Serial Number (also called Key Name, in ANSI X9.24) needed to derive the transaction key     * @param bdk Base Derivation Key, used to derive the transaction key underwhich the pin is encrypted     * @param kd2 the destination Data Key (also called session key) under which the pin will be encrypted     * @param destinationPINBlockFormat the PIN Block Format of the translated encrypted PIN     * @return pin encrypted under kd2     * @throws SMException     */    public EncryptedPIN translatePIN (EncryptedPIN pinUnderDuk, KeySerialNumber ksn,            SecureDESKey bdk, SecureDESKey kd2, byte destinationPINBlockFormat) throws SMException;    /**     * Exports a PIN from encryption under LMK to encryption under a KD     * (Data Key).     *     * @param pinUnderLmk pin encrypted under LMK     * @param kd2 the destination data key (also called session key) under which the pin will be encrypted     * @param destinationPINBlockFormat the PIN Block Format of the exported encrypted PIN     * @return pin encrypted under kd2     * @throws SMException     */    public EncryptedPIN exportPIN (EncryptedPIN pinUnderLmk, SecureDESKey kd2, byte destinationPINBlockFormat) throws SMException;    /**     * Generates CBC-MAC (Cipher Block Chaining Message Authentication Code)     * for some data.     *     * @param data the data to be MACed     * @param kd the key used for MACing     * @return the MAC     * @throws SMException     */    public byte[] generateCBC_MAC (byte[] data, SecureDESKey kd) throws SMException;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -