Android NFC手机如何实现卡模拟
问题:Android NFC手机如何实现卡模拟?
描述:Android NFC手机如何实现卡模拟?最近HCE技术被广泛宣传,其中关于Android NFC手机卡模拟收到开发者和应用系统集成商的青睐,如何用Android NFC手机实现卡模拟呢?
答案:在技术上可行,但是,对一般开发人员来讲有两种方式:一种是基于硬件的,被称为虚拟卡模式(Virual Card Mode);一种是基于软件的,被称为主机卡模式(Host Card Mode)。
在虚拟卡模式下,需要提供安全模块SE,NFC芯片作为非接触通讯前端,将从外部读写器接收到命令,转发到SE,然后由SE进行回复。
外部读写器 <---> NFC芯片 <---> SE。
而在主机卡模式下,不需要提供SE,而是由在手机中运行的一个应用完成SE的功能。
NFC读写器 <---> NFC芯片 <---> 主机上的应用。
什么是“SE”呢?
SE可以理解成一个CPU卡,一般是带有JAVA虚拟机的CPU卡,即JAVA卡。带有NFC芯片的手机一般都带有SE(也可能有例外),例如 GOOGLE NEXUS手机的PN65N,就是PN544芯片加SmartMX安全模块。此外,SE也可以是特殊的SIM卡或SD卡。
根据SE硬件的不同,SE与主机的硬件接口也有所不同。对内置的SE,一般是NFCWI接口,而SIM和SD卡可能是SWP接口。应用接口协议是
ISO7816-4,即CPU卡APDU命令。熟悉CPU卡的都知道,没有密钥,根本无法完成对卡的写操作。因此需要SE的操作密钥。但不幸的是,这些密
钥都掌握在手机厂商(内置SE的情况),例如三星,HTC,或移动运营商(SIM的情况),或者银行等安全模块提供商(SD卡的情况)手中,一般开发人员
是得不到这些权限的。