[导读] NFC是“近场通讯”的简称,采用短距离RF(射频)通讯技术。 关键词:

  NFC智能手机

  NFC技术发展

  NFC是“近场通讯”的简称,采用短距离RF(射频)通讯技术。NFC 工作频率为13.56Hz,有效范围为500px 以内,其传输速度有106 Kbit/秒、212 Kbit/秒或者424 Kbit/秒三种,能够应用在手机/平板、电脑/游戏机、印表机、电子产品,甚至家电设备中。

  NFC技术已经有十来年历史,在过去的几年里一直被称为很有前景的便利移动支付技术。但即使在NFC手机日渐成为智能机标配的今天,基于NFC 的移动支付却没有在消费者群体中形成气候。一个重要的原因在于:所有人都在争着控制NFC 技术的安全元件(the Secure Element)。安全元件,顾名思义,是保证财产信息安全的,控制这个就可以控制每一笔交易的费用。SE导致了金融机构、OEM和运营商之间无休止的争斗,没办法联合起来,这使得NFC移动支付发展缓慢。

  HCE概念

  HCE(host-based cardemulation),即基于主机的卡模拟。

  在一部配备NFC功能的手机实现卡模拟,目前有两种方式:一种是基于硬件的,称为虚拟卡模式(Virtual Card Mode);一种是基于软件的,被称为主机卡模式(Host Card Mode)。

  在虚拟卡模式下,需要提供安全模块SE(Secure Elemen),SE提供对敏感信息的安全存储和对交易事务提供一个安全的执行环境。NFC芯片作为非接触通讯前端,将从外部读写器接收到的命令转发到SE,然后由SE处理,并通过NFC控制器回复。

  在主机卡模式下,不需要提供SE,而是由在手机中运行的一个应用或云端的服务器完成SE的功能,此时NFC芯片接收到的数据由操作系统或发送至手机中的应用,或通过移动网络发送至云端的服务器来完成交互。两种方式的特点都是绕过了手机内置的SE的限制。这一标准的妙处在于,它不需要整个行业为了控制安全元件而争斗。

  使用基于主机的卡模拟时(HCE),NFC 控制器从外部读写终端接收到的数据将直接被发送到主机系统上,而不是安全模块。上图描述了这个过程。

  HCE技术的关键大事记

  2012/09/19,SimplyTapp在Android第三方CyanogenMod固件中实现主机卡模拟技术HCE;

  2013/11/01,Google发布最新的Android4.4操作系统,支持主机卡模拟HCE技术,目前已通过谷歌钱包将HCE应用到Nexus 5手机中,可支持Paypass;

  2013/12/13,美国连锁咖啡TimHortons在北美4000多家门店推出基于HCE的NFC支付应用;

  2014/02/17,西班牙银行Bankinter发布基于HCE技术的虚拟卡手机钱包;

  2014/02/19,Visa和万事达卡同时宣布将基于HCE技术推动云端移动支付;

  2014/02/20,全球智能卡制造商ABnote与SimplyTapp合作,将HCE技术加入到其TSM平台中。

  NFC标准对Android支持

  NFC标准对很多智能卡通讯协议提供了支持,而Android4.4系统也支持包括主流智能卡应用在内的很多非接触智能卡协议,因此使用NFC手机和HCE应用,就可以方便的模拟出不同类型的智能卡应用。

  同样市场上很多NFC读卡终端也支持这些协议,包括一部支持NFC的Android设备作为读卡器本身。这样通过HCE技术我们只用Android设备就可以部署一个端对端的NFC解决方案。

  Android4.4系统使用NFC论坛制定的的ISO-DEP标准协议(基于ISO/IEC14443-4(ISO-DEP)标准)进行数据传输,传输的数据单元被称为应用协议数据单元(APDUs)。

  另外,在数字协议方面(相当于MAC层协议)Android系统只要求对顶层的NFC-A(ISO/IEC 14443-3 Type A)技术提供支持,而对NFC-B技术的(ISO/IEC 14443-3 Type B)的支持则是可选的,这些技术提供了包括初始化、冲突检测等解决方案。

  Android系统上的HCE技术是通过系统服务实现的(HCE服务)。使用服务的一大优势是它可以一直在后台运行而不需要有用户界面。这个特点就使得HCE技术非常适合像会员卡、交通卡、门禁卡这类的交易,当用户使用时无需打开程序,只需要将手机放到NFC读卡器的识别范围内,交易就会在后台进行。当然更推荐为用户提供配套的HCE应用UI界面,这样除了像普通的智能卡片一样刷卡使用以外,还可以通过UI界面为用户提供更多的在线服务功能,包括查询、充值和信息推送等。

  当用户将手机放到NFC读卡器的识别范围时,Android系统需要知道读卡器真正想要和哪个HCE服务交互,这样它才能将接收到的数据发送到相应的HCE应用。HCE参考ISO7816规范,定义了一种通过应用程序AID来选择相应应用的方法。因此,如果要为自己的新的读卡设施部署NFC应用,就需要定义自己的AID。

  HCE技术实现NFC模拟

  在手机上用HCE技术实现NFC卡模拟,首先要创建一个处理交易事务的HCE 服务,Android4.4为HCE服务提供了一个非常方便的基类,我们可以通过继承基类来实现自己的HCE服务。如果要开发已存在的NFC系统,我们只需要在 HCE 服务中实现NFC 读卡器期望的应用层协议。反之如果要开发自己的新的NFC 系统,我们就需要定义自己的协议和APDU 序列。一般而言我们应该保证数据交换时使用很少的APDU包数量和很小的数据量,这样用户就不必花很长时间将手机放在NFC 读卡器上。

  HCE 技术只是实现了将NFC 读卡器的数据送至操作系统的HCE 服务或者将回复数据返回给NFC 读卡器,而对于数据的处理和敏感信息的存储则没有具体实现细,所以说到底HCE 技术是模拟NFC 和SE 通信的协议和实现。但是HCE 并没有实现SE,只是用NFC 与SE 通信的方式告诉NFC 读卡器后面有SE的支持,从而以虚拟SE 的方式完成NFC 业务的安全保证。既然没有SE,那么HCE 用什么来充当SE 呢,解决方案要么是本地软件的模拟,要么是云端服务器的模拟。负责安全的SE如何通过本地化的软件或者远程的云端实现,并且能够保障安全性,需要HCE厂商自己考虑和实现。

  HCE方案与SE方案的路由和兼容

  支持HCE功能的Android4.4手机,很多也同时支持SWP-SIM或者SWP-SD之类的SE模式实现手机支付功能,因此存在一个应用 AID路由的问题,通常是由CLF芯片中的AID路由表来负责进行相关的路由工作,由手机生产厂商负责开发实现具体的规则。具体系统架构和指令流向如下图:

  因为CLF芯片的路由表,是通过读卡终端发送的Select指令中的应用AID来进行区分和路由的,因此对于SE(SWP-SIM)和手机 HOSTCPU中的HCE应用,如果各自支持的具体智能卡应用的AID均不相同,则不会出现任何路由和兼容性的问题,所有的应用均能够被正确识别和分别路由到SE(SWP-SIM)或者HCE应用,并正常完成交易的实现和处理。

  如果SE(SWP-SIM)和手机HOST CPU中的HCE应用,支持的智能卡应用中有相同的AID,则存在一个路由优先级的问题,同时涉及到支持SE(SWP-SIM)的设备升级到Android4.4之后,对于SWP-SIM中原有的应用的兼容问题。

  按照google提供的Android API的要求,HCE APP的路由优先级更高,表示说如果存在相同的AID的应用,则会被优先路由到HCE应用来处理,那么SWP-SIM中的相同AID的应用将无法被调用和使用,会出现系统升级到4.4版本后,无法兼容既有应用使用的问题,除非不安装HCE 应用。

  因此运营商的定制手机,通常会要求修改一下路由的优先级,使SE(SWP-SIM)的路由优先级更好,即如果存在相同的AID的应用,则会被优先路由到SWP-SIM来处理,确保对于旧时发行的支持SE的设备,在系统升级到4.4之后的兼容性。

HCE知识盘点:大事记、NFC卡模拟、与SE兼容相关推荐

  1. android的nfc卡模拟开发

    这是andorid官方文档对于卡模拟方式的描述: https://developer.android.google.cn/guide/topics/connectivity/nfc/hce 有两种方式 ...

  2. android nfc识别身份正_[Android] NFC卡模拟专业版 用手机自带NFC开小区门禁 刷食堂饭卡...

    声明:免费分享,请勿买卖 Card Emulator Pro是一个功能强大且免费的NFC卡模拟器,可模拟各类门禁卡.电梯卡.部分公司工厂工卡或饭卡.部分学校饭卡.部分图书馆借书卡 等各类IC卡,用手机 ...

  3. html调用手机NFC,NFC门禁模拟-教你用NFC手机模拟门禁卡

    注意,本文针对未加密门禁模拟,加密门禁请看这里: 使用本程序可以让手机的NFC模拟各种门禁卡片,从而可以用手机代替门禁卡,文末提供演示.我默认用户朋友都是IT高手,所以小白请学习相关知识后再入坑. 使 ...

  4. id nfc模拟_NFC卡模拟app-NFC卡模拟安卓版下载v6.0.0 - 7230手游网

    NFC卡模拟app是款功能强大的模拟卡片软件,软件非常的实用,模拟各种卡,操作起来非常的方便,只需一个手机就能使用多种卡,喜欢的话快来下载吧. 软件介绍 NFC卡模拟是一款功能十分强大的免费模拟卡片的 ...

  5. 安卓 NFC 主机卡模拟

    安卓 NFC 卡模拟 StackOverFlow:Android HCE: are there rules for AID? 主机卡模拟Demo 第一步 新建类CardEmulatorService ...

  6. nfc 简单卡模拟demo

    NFC卡模拟是一个功能强大且的NFC卡模拟器,可模拟各类门禁卡.电梯卡.部分公司(工厂)工卡或饭卡.部分学校饭卡.部分图书馆借书卡等各类IC卡,用手机替代卡片去刷门禁.刷电梯.刷考勤和刷饭堂等等,支持 ...

  7. nfc pm3 模拟加密门禁卡_华为手机NFC的妙用,模拟门禁卡、公交卡、银行卡,电子证件等...

    你关注的才是晋圈 出门带门禁卡.银行卡.身份证--这些东西真的是很麻烦,有没有一种方法可以把它们都装下?有!只要一部手机,出门不带包,各种证件,各种卡通通装进手机. 首先要你的手机支持NFC功能,我们 ...

  8. 判断门禁卡是否加密_离无卡生活更进一步!判断您的门禁卡能否被手机NFC功能模拟...

    第一步要判断门禁卡是否能够被模拟 先看看小米手机如何判断 如果是小米手机,其中高端产品在MIUI9.5 稳定版以后,在小米钱包里面增加了门卡模拟功能.如果在门卡模拟界面,根本就识别不了门禁卡,那么说明 ...

  9. 手机可以模拟但小米手环4(nfc)不能模拟加密卡的简单解决方案

    手机可以模拟但小米手环4(nfc)不能模拟加密卡的简单解决方案 设备 一台手机(自己的)用来使用小米运动 一台手机 机型 小米MIX2(带nfc) ps 其他品牌手机不一定可以 一张部分加密的门禁卡 ...

最新文章

  1. 如何学好机器学习数据挖掘?这本《数据分析数学基础》图文并茂带你学习入门...
  2. IIS7.5+WebConfig实现页面伪静态和301重定向
  3. easyui treegrid idField 所在属性中值有花括号(如Guid)当有鼠标事件时会报错,行记录一下...
  4. poj 3662 Telephone Lines(好题!!!二分搜索+dijkstra)
  5. Kubernetes二进制部署——Flannel网络
  6. 9.6Gbps WiFi联盟宣布802.11ax协议!
  7. idea提高调试超时_如何提高您的调试技能
  8. 【CentOS】NFS服务器的安装与配置
  9. 成绩转换(百分制到五级制的转换)-(只作新手参考)
  10. windows无法移动修复此计算机,无法安装Windows 10移动创作者更新[修复] | MOS86
  11. Ubuntu下超实用的命令
  12. [UE4]暂停游戏、退出游戏、游戏输入模式
  13. python爬去微博签到数据_GitHub - fs6/weiboSpider: 新浪微博爬虫,用python爬取新浪微博数据...
  14. 计算机网络四个阶段的主要特征,1计算机的四个发展阶段的主要特征
  15. 抖音短视频去水印网站 视频消重防删免费
  16. 如何对计算机的系统文件和设置进行更改,Windows 系统常用设置方法与技巧
  17. Redis的前前后后左左右右
  18. 山大计算机学院夏令营2021,关于举办山东大学2021年暑期未来数学家夏令营的通知...
  19. Foo = Foo||Bar ,这行代码是什么意思?为什么要这样写?
  20. 《德米安》从那以后伤口很痛,但偶尔我会找到钥匙,沉入心底

热门文章

  1. php后台开发—微信分销那点事
  2. 互联网摸鱼日报(2022-11-22)
  3. 【ACM_1】H - Line Gimmick
  4. 射频信号中的邻道功率比(ACPR)和占用带宽(OBW)与测量方法
  5. ACPR'11 Accepted
  6. Zemax操作6--激光扩束镜
  7. 谨慎使用viewWithTag
  8. oracle查询远程视图进行insert语句报错:ORA-00600: 错误 [qerrmOFBu1], [24347], []
  9. h5跳转到小程序总是出现页面不存在-微信小程序开发
  10. ct与x光的哪个辐射大_X线、CT、B超、核磁哪个辐射大?你绝对想不到!