《基于JavaCard的NFC移动智能应用系统研究与安全设计.docx》由会员分享,可在线阅读,更多相关《基于JavaCard的NFC移动智能应用系统研究与安全设计.docx(8页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、基于JavaCard的NFC移动智能应用系统研究与安全设计0引言近几年来,随着移动智能科学技术的不断发展,移动智能终端具有广泛应用于各大行业领域的潜力,移动电子支付通信服务领域也不例外1。移动智能电子支付市场没有被完全开拓,主要包括以下几个方面的原因2:(1)移动智能电子支付应用效率低,支付流程复杂;(2)电子支付安全性无法保证,其核心技术不成熟;(3)远程移动电子支付服务单一、支付内容不丰富;(4)移动智能电子支付的利益机制尚不完善等。这些都对移动智能电子支付的市场推广产生一定影响,因此,移动智能电子支付在中国的推行受到了诸多限制3。针对上述存在的各种问题,为了进一步改善与提高移动智能终端在
2、移动电子支付通信服务方面的高效性、应用性与安全性,本文在深入分析JavaCard和NFC技术的理论基础上4,从移动智能电子支付核心技术机制出发,提出了一种以JavaCard智能卡技术原理与NFC移动智能技术的理论知识为前提的移动智能支付应用系统模型框架,提高了移动智能电子支付过程的便携性、应用性;并且针对多标签情况下的碰撞问题设计了一种基于动态二进制防碰撞算法的应用支付安全方案,确保了移动智能电子支付过程中的安全性5。1JavaCard智能卡技术JavaCard是Java平台中最小的subset开发平台,其设定的执行环境为SmartCard上的晶片或是有严格硬体限制的环境6。JavaCard的
3、问世,一方面是为了推展Java的应用层次,另一方面是为了将Java平台的特性以及JavaCard的优势带到SmartCard上,这些优势主要有:(1)Platform-Independent:使得JavaCardapplets(在JavaCard上执行的程式)能够在不同卡片的JCAE(JavaCardApplicationEnvironment)上执行,即通过JavaVM机制来达到跨平台的能力;(2)Multi-ApplicationCapable:在同一个Java-Card中能够存放多个JavaCardapplets,并且也能够通过下载方式来获取必要的applets而达到一卡多用的目的,使得
4、卡的使用能够更有弹性;(3)CompatiblewithExistingSmartCardStandar-ds:JavaCard智能卡能与国际标准ISO7816(SmartCard标准)以及工业界标准如Europay/MasterCard/Visa(EMV)相容。所以,在未来JavaCard不但能够取代SmartCard的功能,更能够发展出多样化的应用,其中移动智能电子支付就是其中之一,甚至能将许多不同的应用程序集合于一张卡上,使得这些随身的软件能够更小更实用。2基于JavaCard的NFC移动智能应用系统2.1NFC移动智能生态模型的构建NFC移动智能生态系统是基于RFID技术发展的一种非接
5、触式的移动智能电子应用系统原型,其主要包括移动智能终端用户群体、移动运营机构、银行金融机构、相关服务提供厂商、NFC移动智能终端制造厂商等,如图1所示。2.2移动智能应用系统模型(1)模型框架描述基于JavaCard的NFC移动智能应用系统模型主要包含两大部分:电子支付应用与非电子支付应用。如图2所示。从模型设计中可知,非电子支付应用环节一般由娱乐、防伪、私人门禁等方面组成,移动智能终端用户需通过计算机网络与备份数据信息库对电子产品做进一步防伪认证。其电子支付应用环节一般由移动智能终端用户、制造厂商/产品提供厂商、移动网络运营机构和金融机构等组成。(2)移动智能终端支付银行选择模块现有的移动智
6、能电子支付应用系统中在银行卡的选取方面较为固定,不能动态地对其绑定的银行电子支付手段与方式进行选择,因此,本文在基于JavaCard的NFC移动智能应用系统模型的设计中特别添加了移动智能终端支付银行选择模块,实现电子支付过程中的动态与便捷。如图3所示。具体选择流程如下:选取多户银行并进行开户业务,包括移动电子支付业务;通过移动智能终端获取其应用系统APP;第一次使用时进行设置,包括默认设置,如设置默认银行卡号、绑定默认联系方式等,或者依据添加时间的先后对银行卡的选取进行管理,默认银行卡是第一支付选择的卡号,余下银行卡添加到备选银行卡清单之中;若默认或当前选取的银行卡无法进行支付操作,将自动提示
7、选取下一个邻近时间点的银行卡作为支付银行卡,依次类推,直到支付成功为止。3改进的动态二进制防碰撞算法设计为了满足移动智能电子支付应用系统的安全需求,本文对传统二进制搜索算法进行改进。接下来将对改进的动态二进制防碰撞算法进行详细分析。(1)基本指令描述为了描述这个算法,假设标签标识号NFCID的位数为n,即从高位到低位分别为Dn-1Dn-2.D1D0,出现多标签冲突的位数为m(0mSEL_REQ(x,Dm):读卡器传输一个数值x(x属于1或者0)给相关范围内的标签申请回复,若标签号出现冲突的最后一位到第一位这m个数值中有一个或多个数值位与满足要求的标签回复相一致(以便于降低初始化标签区域面积大小
8、,做出相应优化)。说明:第1次询问时,x=n,使用NULL表示标签号无数值,即空值,所以申请回复指令是:SEL_REQ(NULL,Dn-1)。SELRES(m):获取到余下冲突位置的数据(第m-1至第1位),记录未出现冲突位置的数据。SR_DATA:选取满足条件的标签,且获取其数值信息:对符合条件的标签,将其存储的相关数值信息传输给读卡器等相关设备。Unsel:将多个预定选取中的一个标签进行取消操作,此标签转换到“无声状态。此时这个标签处于未被激活状态,对其步骤中的申请指令SEL_REQ不作出任何答复。当远离读卡器感应操作区域之外时,才能进行标签复位操作,这样使得标签能够重新被激活。(2)改进
9、算法原理若NFCID为8bit,则读卡器作用区域内有多个标签,这里以5个为实例,标签分别为:11100101、10100110、11010100、1000011、10101110。读卡器将利用该算法来识别它们。初始化阶段,读卡器对区域内标签处于未知状态,所以发送SEL_REQ(NULL,8)命令,要求作用范围内任何一个标签做出应答信息。详细执行过程如图4所示。4结束语本文以JavaCard智能卡技术原理与NFC移动智能技术的理论知识为前提,首先提出了一种基于JavaCard和NFC技术的移动智能支付应用系统的模型框架,并在该模型中设计了移动智能终端支付银行选择模块;其次针对多标签情况下的应用支
10、付碰撞问题设计了一种改进的动态二进制防碰撞算法。研究分析表明,应用支付模型框架与防碰撞安全算法在移动电子支付通信服务方面均达到了次优化的应用与安全效果。参考文献1NaoyaS,MasakazuU,YasuhiroT.DesigntechniguestoreducepowerconsumptionforARM946E-ScoreJ.OkiTekunikaruRebyu,2005,72(3):52-55.2张德学,郭立,傅忠谦.面积优化与低功耗设计的JavaCard处理器J.中国科学技术大学学报,2008,(38)3:289-292.3李翅.基于JavaCard和NFC技术的手机钱包关键技术研究D.长沙:湖南师范大学,2009.4林龙,张果,王剑平,等.基于NFC技术的标签模式设计J.微处理机,2013,3(3):31-36.5ETSI.TS102622v7.6.0,2010.04,SmartCards,UICC-ContactlessFront-end(CLF)Interface;HostControllerInterface(HCI)(Release7)S.PreparedbytheEuropeanTelecommunicationsStandardsInstitute,2010.6宋海燕.基于Android的NFC文件传输系统的设计与实现D.北京:北京邮电大学,2012. 1