- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
本程序设计文档
1.概述
本Applet是根据《EMV Integrated Circuit Card Specifications for Payment Systems v4.3》及《Visa Integrated Circuit Card Specification》系列国际规范,基于NXP的JCOP平台,开发的用于金融交易的软件产品。
本Applet运行的平台要求:支持JAVA CARD 2.2.1及以上版本、Global Platform v2.1.1及以上版本的JAVA 虚拟机。
个人化按照规范《EMV Card Personalization Specification v1.1》,采用《Global Platform Card Specification v2.1.1》规范中定义的Store data命令,使用DGI作为数据分组标识。能够达到快速发卡,可二次发卡的功能。
2.包(Package)
本Applet包的设计可以有两种方式供选择:
1. 单package设计:即所有类都在一个包中,优点是整个工程结构简单,程序运行时减少包与包之间变量传递等,减低效率损耗,缺点是文件系统部分没有单独做一个package,不能以后直接拿出来给其它applet使用;
2. 双package设计:即文件系统单独做一个包,功能部分做另一个包,其优缺点跟单package是对应的,即可能会使结构复杂,增加效率损耗,优点是文件系统如果设计的比较全面,可以在以后其它applet中拿来直接使用。
在本Applet中,倾向于选择第一种,单package设计,因为以后的applet对文件系统的需求并不确定,目前设计文件系统不一定完全满足需求,或者不需要这么大的系统,反而生成的cap文件占用了较大的卡片空间。
以下对采用单Package设计包含的类结构进行大致描述:
图1 类结构图
以下将对各个类分别进行描述。
3.EMVApplet类
本类的声明如下:
public class EMVApplet extends Applet implements Application,AppletEvent
本类是本软件中最重要的类。在本类中,要完成所有EEPROM空间的申请,包括文件创建和密钥体创建等;要对个人化写入的数据进行处理,分别写入对应的记录文件、数据对象或密钥对象中;此外,更重要的是,本类还要实现所有APDU命令的处理。
3.1EMVApplet构造方法
EMVApplet构造方法定义本类中需要用到的全局变量,创建其它类的实例,创建所有文件和密钥、PIN都在此方法中完成。其中密钥方面,对称密钥(3DES密钥)可以直接使用buildkey进行创建,RSA密钥位数在Common类中已经进行配置,直接创建对象;此外,PIN值、长度、最大重试次数也已经在Common中定义了常量。
记录文件的创建也在此方法中完成,举例:
RecordFile[] EF;
EF[0] = new RecordFile((short)0x01,(short)800,(byte)UNDER_PSE);
EF[1] = new RecordFile((short)0x02,(short)500,(byte)UNDER_ADF);
密钥对象的创建举例:
RSA_PriK_Crt =(RSAPrivateCrtKey)KeyBuilder.buildKey(
KeyBuilder.TYPE_RSA_CRT_PRIVATE,
Common.RSA_KEY_LENGTH,
false);
为了提高交易效率,以下个人化阶段写入的变量在本类中定义初始值:
TAG
变量定义
9F36
Public byte[] ATC
9F13
Public byte[] LAST_ONLINE_ATC
9F27
Public byte CID
9F10
Public byte[] ISS_APP_DATA
表1 EMVApplet中定义的交易数据对象
3.2Process和ProcessData方法
Process方法是所有APDU的命令入口,进入各条命令处理之前,应用需要做一些卡片生命周期判断。
ProcessData主要是处理个人化阶段STORE DATA命令传递进来的数据,我们需要做的是接收数据,获取DGI标识,分别写入对应的记录或其它预先定义的变量中。对于RSA私钥和DES密钥,需要密文传入,卡内要知道此用于密钥解密的密钥,写入对象前解密。DGI与对象的对应表如下:
DGI
名称
类型
用途
0B01
PSE下DIR文件
记录,只有一条记录的记录文件中
写入DIR信息
0101
EF[0]第一条记录
记录
写交易数据,通过readrecord返回给终端
0102
EF[0]第二条记录
记录
写交易数据,通过
您可能关注的文档
最近下载
- 食品经营(仅销售预包装食品)备案申请表-模板.pdf VIP
- 宁夏枣泉电厂一期工程的环境影响的报告书简本.doc VIP
- 2022年国家公务员录用考试行测常识题库及答案(共1344题).pdf VIP
- (人教PEP2024版)英语三年级上册全册大单元教学设计(新教材).docx
- 北京交通大学DSP系统课程设计报告电话拨号音检测.docx VIP
- 妇产科规培年度述职报告.docx VIP
- 【庄歌】黄沙坪矿区生产实习.doc VIP
- 2025届高考英语二轮复习:非谓语动词课件 (共49张PPT).ppt.pptx VIP
- 一种驱虫斑鸠菊提取物的外用制剂及其制备方法.pdf VIP
- 杭州优迈SMART系统中文标示电气原理图.pdf VIP
文档评论(0)