JavaCard Applet运行机制 -- JavaCard开发

本文介绍了JavaCard Applet的运行步骤,包括卡片复位、设置密钥、外部认证、删除与上传Applet、选择与执行指令。在调试过程中,首先选择Applet,然后发送自定义命令进行调试。外部认证与内部认证的区别在于密文产生的位置,两者都是通过随机数和密钥进行验证。.cap文件是JavaCard的字节码文件,与标准Java有所不同。
摘要由CSDN通过智能技术生成

JavaCard Applet运行步骤如下:

  • 打开终端 /term
  • 卡片复位 /card
  • 设置密钥 set-key init-update
  • 外部认证 ext-auth plain
  • 删除相应AID的package delete AID
  • 删除相应AID的applet delete AID
  • 上传cap包到卡片 upload
  • 查看卡片/applet信息 card-info
  • 选择相应AID的applet /select AID
  • 终端发送指令 /send

以下是我在ecplise点击运行自己创建的JavaCard Applet后JCOP shell自动执行的命令截图:

其中 set-key 是注册好卡片的密钥,在后面要做外部认证;

init-update 执行初始化更新命令,CardManager开始认证;

ext-auth plain 完成了外部认证,并输出文本信息;

由于我已经安装过了AID为1535220901的package和AID为153522090101的applet,所以先删除这些文件;

然后将新的applet对应的cap文件上传到卡片中;

javacard applet 开发实例 正常运行 带jar包 package mifare; import com.ibm.jz.JZSystem; import javacard.framework.APDU; import javacard.framework.Applet; import javacard.framework.ISO7816; import javacard.framework.ISOException; import javacard.framework.Util; public class AmbiqApplet extends Applet { byte[] mifarePassDefault={(byte)0x0b,(byte)0x54,(byte)0x57,(byte)0x07,(byte)0x45,(byte)0xfe,(byte)0x3a,(byte)0xe7}; byte[] mifarePass8={(byte)0x0b,(byte)0x54,(byte)0x57,(byte)0x07,(byte)0x45,(byte)0xfe,(byte)0x3a,(byte)0xe7}; byte[] mifarePass9={(byte)0x0b,(byte)0x54,(byte)0x57,(byte)0x07,(byte)0x45,(byte)0xfe,(byte)0x3a,(byte)0xe7}; byte[] adminPass={(byte)0x40,(byte)0x41,(byte)0x42,(byte)0x43,(byte)0x44,(byte)0x45,(byte)0x46,(byte)0x47,(byte)0x48,(byte)0x49,(byte)0x4a,(byte)0x4b,(byte)0x4c,(byte)0x4d,(byte)0x4e,(byte)0x4f}; public static void install(byte[] bArray, short bOffset, byte bLength) { // GP-compliant JavaCard applet registration new AmbiqApplet().register(bArray, (short) (bOffset + 1), bArray[bOffset]); } public void process(APDU apdu) { short i; byte[] send=new byte[52]; byte[] send2=new byte[24]; // Good practice: Return 9000 on SELECT if (selectingApplet()) { return; } byte[] buf = apdu.getBuffer(); if(buf[ISO7816.OFFSET_CLA]==AmbiqConstant.CLS_AMBIQ) { switch (buf[ISO7816.OFFSET_INS]) { case AmbiqConstant.INS_GET_MIFARE: if(buf[ISO7816.OFFSET_P1]!=0 || buf[ISO7816.OFFSET_P2]!=0) { ISOException.throwIt(ISO7816.SW_INCORRECT_P1P2); return; } /*Get Entire Mifare Ticket data * Returns back the content of the entire sector 8 (3 block 8.0, 8.1, 8.2) and the first 4 bytes of block 9.0; total 52bytes. Filed Length (in bytes) Data Comments CLA 1 0x80 Fixed class for the applet INS 1 0x20 Read entire data P1 1 0x00 Sector number P2 1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值