2015-05-25 50 views
-5

我無法獲取我的經典java卡應用程序的PIN號碼。我必須編寫APDU命令來驗證PIN碼。如何在java卡技術中驗證錢包應用程序的PIN碼?

請幫助我如何獲得PIN碼

**Wallet.java** 

package wallet; 

import javacard.framework.*; 

public class Wallet extends Applet { 

    /** 
    * Installs this applet. 
    * 
    * @param bArray the array containing installation parameters 
    * @param bOffset 
    * the starting offset in bArray @param bLength 
    * the length in bytes of the parameter data in bArray 
    */ 


    // code of CLA byte in the command APDU header 
    final static byte Wallet_CLA =(byte)0xB0; 

    // codes of INS byte in the command APDU header 
    final static byte VERIFY = (byte)0x20; 
    final static byte CREDIT = (byte)0x30; 
    final static byte DEBIT = (byte)0x40; 
    final static byte GET_BALANCE = (byte)0x50; 

    // maximum balance $32,76 
    final static short MAX_BALANCE = 0x7FFF; 
    // maximum transaction amount 
    final static byte MAX_TRANSACTION_AMOUNT = 127; 

    // maximum number of incorrect tries before the PIN is blocked 
    final static byte PIN_TRY_LIMIT =(byte)0x03; 

    // maximum size PIN 
    final static byte MAX_PIN_SIZE =(byte)0x08; 

    // signal that the PIN verification failed 
    final static short SW_VERIFICATION_FAILED = 0x6300; 

    // signal the the PIN validation is required 
    // for a credit or a debit transaction 
    final static short SW_PIN_VERIFICATION_REQUIRED = 0x6301; 

    // signal invalid transaction amount 
    // amount > MAX_TRANSACTION_AMOUNT or amount < 0 
    final static short SW_INVALID_TRANSACTION_AMOUNT = 0x6a83; 

    // signal that the balance exceed the maximum 
    final static short SW_EXCEED_MAXIMUM_BALANCE = 0x6a84; 

    // signal the the balance becomes negative 
    final static short SW_NEGATIVE_BALANCE = 0x6a85; 

    /* instance variables declaration */ 
    OwnerPIN pin; 
    short balance; 

    protected Wallet (byte[] bArray,short bOffset,byte bLength){ 

     // It is good programming practice to allocate all the memory that an applet needs during 
     // its lifetime inside the constructor 
     pin = new OwnerPIN(PIN_TRY_LIMIT, MAX_PIN_SIZE); 

     // The installation parameters contain the PIN initialization value 
     //  pin.update(bArray, bOffset, bLength); 
     // Above command causes error. 
     register(); 

    } // end of the constructor 

    public static void install(byte[] bArray, short bOffset, byte bLength){ 
     // create a Wallet applet instance 
     new Wallet(bArray, bOffset, bLength); 
    } // end of install method 

    public boolean select() { 
     // The applet declines to be selected if the pin is blocked. 
     if(pin.getTriesRemaining() == 0) 
      return false; 

     return true; 
    }// end of select method 

    public void deselect() { 
     // reset the pin value 
     pin.reset(); 
    } 

    /** 
    * Processes an incoming APDU. 
    * 
    * @see APDU 
    * @param apdu 
    * the incoming APDU 
    */ 

    public void process(APDU apdu) { 
     byte buffer[] = apdu.getBuffer(); 
     // check SELECT APDU command 
     if ((buffer[ISO7816.OFFSET_CLA] == 0) && (buffer[ISO7816.OFFSET_INS] == (byte)(0xA4))) 
      return; 
     // verify the reset of commands have the correct CLA byte, which specifies the command structure 
     if (buffer[ISO7816.OFFSET_CLA] != Wallet_CLA) 
      ISOException.throwIt(ISO7816.SW_CLA_NOT_SUPPORTED); 

     switch (buffer[ISO7816.OFFSET_INS]) { 
      case GET_BALANCE: getBalance(apdu); 
           return; 
      case DEBIT:   debit(apdu); 
           return; 
      case CREDIT:  credit(apdu); 
           return; 
      case VERIFY:  verify(apdu); 
           return; 
      default:  ISOException.throwIt(ISO7816.SW_INS_NOT_SUPPORTED); 
     } 
    } // end of process method 


    private void verify(APDU apdu) { 
     byte[] buffer = apdu.getBuffer(); 
     // retrieve the PIN data for validation. 
     byte byteRead = (byte)(apdu.setIncomingAndReceive()); 

     // check pin the PIN data is read into the APDU buffer at the offset ISO7816.OFFSET_CDATA 
     // the PIN data length = byteRead 
     if (pin.check(buffer, ISO7816.OFFSET_CDATA, byteRead) == false) 
      ISOException.throwIt(SW_VERIFICATION_FAILED); 

    } 

} 


**wallet.scr** 

powerup; 
// Select Wallet //aid/B239C74B30/39 
0x00 0xA4 0x04 0x00 0x06 0xB2 0x39 0xC7 0x4B 0x30 0x3A 0x7F; // check 0x3A 0x7f 

//Send the APDU here 
// verify 
0xB0 0x20 0x00 0x00 0x06 0xB2 0x39 0xC7 0x4B 0x30 0x3A 0x7F; 

// credit 
0xB0 0x30 0x00 0x00 0x01 0x09 0x7F; 
//0x80 0xCA 0x00 0x00 <length> <data> 0x7F; 

// debit 
0xB0 0x40 0x00 0x00 0x01 0x05 0x7F; 

// getBalance 
0xB0 0x50 0x00 0x00 0x01 0x7F 0x02; 
powerdown; 

當我試圖更新引腳,它給了響應爲69 99 應該是什麼APDU命令來安裝的小程序。

+0

-1:您可能/不能從您的小程序獲取PIN碼!通常情況下,您只能「設置」/「更改」並僅「驗證」它。上面的代碼對我們沒有任何意義。請將您的小程序程序添加到問題中。 – Abraham

+0

據我所知,PIN作爲安裝命令中的安裝參數。 – JavaCardOS

+0

感謝您的回覆。我編輯了代碼。請指導我如何安裝PIN以及APDU命令應該如何, – Krishnakumar

回答

0

看來你想要在上面的代碼是有Applet的AID作爲引腳值。在這種情況下,你可以檢查AID是否小於MAX_PIN_SIZE。 此外,改變你的構造如下

protected Wallet (byte[] bArray,short bOffset,byte bLength){ 

    // It is good programming practice to allocate all the memory that an applet needs during 
    // its lifetime inside the constructor 
    pin = new OwnerPIN(PIN_TRY_LIMIT, MAX_PIN_SIZE); 

    // The installation parameters contain the PIN initialization value 
    pin.update(bArray, bOffset + 1, bArray[bOffset]); 
    // Above command causes error. 
    register(); 

} // end of the constructor 

這將確保只有AID值將被傳遞到pin.update(),但你仍然需要確保你的AID長度小於MAX_PIN_SIZE,否則PINException .ILLEGAL_VALUE將被拋出。

相關問題